Foreword 



The RCA CDP1802 COSMAC Microprocessor is a one-chip CMOS 
8-bit register-oriented central processing unit. It is suitable for use in 
a wide range of stored -program computer systems and products. 
These systems may be either special or general purpose in nature. 

This User Manual provides a detailed guide to the COSMAC Micro- 
processor. It is written for electronics engineers and assumes only a 
limited familiarity with computers and computer programming. It 
describes the microprocessor architecture and provides a set of 
simple, easy-to-use programming instructions. Examples are given to 
illustrate the operation and usage of each instruction. 

For systems designers, this Manual illustrates practical methods of 
adding external memory and control circuits. Because the processor 
is capable of supporting input/output (I/O) devices in polled, inter- 
rupt-driven, and direct-memory-access modes, detailed examples are 
provided for the use of the I/O instructions and the use of the I/O 
interface lines. The latter include direct-memory -access and interrupt 
inputs, external flag inputs, command lines, processor state indica- 
tors, and external timing pulses. 

This Manual also discusses various programming techniques and 
gives examples. The material covers, in addition to basic guidelines, 
more advanced topics such as interrupt response and subroutine link- 
age and nesting. 

This basic Manual is intended to help design engineers understand 
the COSMAC Microprocessor and to aid them in developing simpler 
and more powerful products utilizing the wide range of microproces- 
sor capabilities. Users requiring information on available hardware 
and software support systems for the CDP1802 Microprocessor 
should also refer to the following publications: 

MPM-202 Timesharing Manual for the RCA CDP1802 COSMAC 

Microprocessor 

MPM-203 Evaluation Kit Manual for the RCA CDP1 802 COSMAC 
Microprocessor 

MPM-206 Subroutine Library for RCA COSMAC Microprocessors 

MPM-208 Operator Manual for RCA COSMAC Development 
System 
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General 

The RCA COSMAC Microprocessor architecture has 
been developed for a wide variety of applications. These 
applications range from replacement of SSI and MSI 
integrated circuits to new applications requiring the full 
flexibility of a computer-based approach. 

The RCA-CDP1 802 is a byte-oriented central process- 
ing unit (CPU) employing the COSMAC architecture and 
utilizing complementary-symmetry MOS technology 
(CMOS). 

CDP1802 operations are specified by sequences of 
instruction codes stored in a memory. Sequences of 
instructions, called programs, determine the specific 
behavior or function of a COSMAC-based system. Sys- 
tt 'unctions are easily changed by modifying the pro- 
giu... stored Ln memory. This ability to change function 
without extensive hardware modification is the basic 
advantage of a stored-program computer. Reduced cost 
results from using identical LSI components (memory 
and microprocessor) in a variety of different systems or 
products. 

The CDP1802 Microprocessor includes all of the cir- 
cuits required for fetching, interpreting, and executing 
instructions which have been stored in standard types of 
memories. Extensive input/output (I/O) control features 
are also provided to facilitate system design. 

Although Microprocessor cost is only a small part of 
total system or product cost (memory, input, output, 
power-supply, system-control, and design costs are also 
major considerations), a unique set of COSMAC features 
combine to minimize the total system cost. For exam- 
ple, the low-power, single-voltage CMOS circuitry mini- 
mizes power-supply and packaging costs. A single-phase 
clock drives the system and an optional on-chip oscilla- 
tor circuit works with an external crystal to provide this 
clock signal. High noise immunity and wide temperature 
tolerance facilitate use in hostile environments. In addi- 



tion, compatibility with standard, high-volume memories 
assures minimum memory cost and maximum system 
flexibility for both current and future applications. Pro- 
gram storage requirements are reduced by means of an 
efficient one-byte operation code. 

The 40-pin system interface of the CDP1802 is de- 
signed to minimize external I/O and memory control 
circuitry. Four directly testable input flags, an output 
flip-flop, an internal direct-memory-access (DMA) mode, 
flexible I/O instructions, program interrupt, program 
load mode, and static circuitry are other features ex- 
plicitly aimed at total system cost reduction. The 
CDP1802 does not require an external bootstrap ROM. 

Microprocessor programming and system design are 
facilitated by the availability of a variety of support pro- 
grams and support hardware. Extensive support software 
and support hardware are available for use in developing 
COSMAC systems. Machine-language programming is 
sometimes indicated when only a few short programs 
need to be developed. A series of efficient, easy -to-learn 
instructions are provided for the CDP1802 which are 
simple to use in machine-language programs. 

Specific Features 

The advanced features and operating characteristics 
of the RCA Microprocessor CDPI802 include: 

■ static CMOS circuitry, no minimum clock fre- 
quency 

■ full military temperature range (-55 to +125°C) 

■ high noise immunity, wide operating-voltage range 

■ TTL compatibility 

■ single-phase clock; optional, on-chip, crystal- 
controlled oscillator 

■ simple control of reset, start, and pause 
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■ 8-bit parallel organization with bidirectional data 
bus 

■ built-in program-load facility 

■ any combination of standard RAM's and ROM's 
via common interface 

■ direct memory addressing up to 65,536 bytes 

■ flexible programmed I/O mode 

■ program interrupt mode 

■ on-chip DMA facility 

■ four I/O flag inputs directly testable by branch 
instruction 

" programmable output port 

r 

■ one-to-three byte instruction format with two 
machine cycles for each instruction* 

a 91 easy-to-use instructions 

■ software compatibility with the CDP1801 

■ 16 X 16 matrix of registers for use as multiple pro- 
gram counters, data pointers, or data registers 

System Organization 

Fig. 1 illustrates a typical computer system incor- 
porating the RCA Microprocessor CDP1802. Operations 
that can be performed include: 

a) control of input/output (I/O) devices, 

b) transfer of data or control information between 
I/O and memory (M), 

c) movement of data bytes between different mem- 
ory locations, 



•Except long-branch and long-skip instructions which require 
three machine cycles. 



d) interpretation or modification of bytes stored in 
memory. 

In such a system, the CDP1802 can, for example, 
control the entry of binary -coded decimal numbers from 
an input keyboard and store them in predetermined 
memory locations. It can then perform specified arith- 
metic operations using the stored numbers and transfer 
the results to an output display or printing device. 

System input devices may include switches, paper- 
tape/card readers, magnetic-tape/disc devices, relays, 
modems, analog-to-digital converters, photodetcctors, 
and other computers. Output devices may include lights, 
relays, CRT/LED/liquid-crystal devices, digital-to-analog 
converters, modems, printers, and other computers. 

Memory can comprise any combination of RAM and 
ROM up to a maximum of 65,536 bytes. ROM (Read- 
Only Memory) is used for permanent storage of pro- 
grams, tables, and other types of fixed data. RAM 
(Random-Access Memory) is required for general- 
purpose computer systems which require frequent pro- 
gram changes. RAM is also required for temporary 
storage of variable data. The type of memory and re- 
quired storage capacity is determined by the specific 
application of the system. 

Bytes are transferred between I/O devices, memory, 
and COSMAC by means of a common, bidirectional 
eight-bit data bus. 

Fifteen I/O control signal lines are provided. Systems 
can use some or all of these signals depending on re- 
quired I/O sophistication. A three-bit N code is gener- 
ated by the input/output instruction. It can be used to 
specify whether an I/O byte on the bus is meant to 
represent data, an I/O device selection code, an I/O 
status code, an I/O control code, etc. Use of the N code 
to specify an I/O device directly permits simple, inex- 
pensive control of a small number of I/O devices or 
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Fig. 1 — Block diagram of typical computer system using the RCA COSMAC 
Microprocessor CDP1802. 
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modes. Use of the N code to specify the meaning of the 
word on the data bus facilitates systems incorporating a 
large number of I/O devices or modes. 

Four I/O flag inputs are provided. I/O devices can 
control these inputs at any time to signal the CDP1802 
that a byte transfer is required, that an error condition 
has occurred, etc. These flags can also be used as binary 
input lines if desired. They can be tested by CDP1802 
instructions to determine whether or not they are active. 
Use of the flag inputs must be coordinated with pro- 
grams that test them. 

An output line (Q) is also available which provides a 
level output whose value is controlled by COSMAC 
instructions. This Q line, -under program control, can 
activate or signal I/O devices. It can also be used in con- 
nection with one of the nag inputs to form a serial I/O 
interface. 

A program interrupt line can be activated at any time 
I/O circuits to obtain an immediate microprocessor 
response. The interrupt causes the CDP1802 to suspend 
its current program sequence and execute a predeter- 
mined sequence of operations designed to respond to the 
interrupt condition. After servicing the interrupt, the 
CDPIS02 resumes execution of the interrupted program. 
The CDPIS02 can be made to ignore the interrupt line 
by resetting its intemipt-enable flip-flop (IE). 

Two additional I/O lines are provided for special 
types of byte transfer between memory and I/O devices. 
These lines are called direct-memory-access (DMA) lines. 
Activating the DMA-in line causes an input byte to be 
immediately stored in a memory location without inter- 
vention by the program being executed. The DMA-out 
line causes a byte to be immediately transferred from 
memory to the requesting output circuits. A built-in 
memory pointer register is used to indicate the memory 
location for the DMA cycles. The program initially sets 
this pointer to a beginning memory location. Each DMA 

"e transfer automatically increments the pointer to 
-.e next higher memory location. Repeated activation of 
a DMA line can cause the transfer of any number of con- 
secutive bytes to and from memory independent of con- 
current program execution. 

I/O device circuits can cause data transfer by acti- 
vating a flag line, the interrupt line, or a DMA line. The 
flag lines must be sampled by the program to determine 
when they become active and are used for relatively slow 
changing signals. Activating the interrupt line causes an 
immediate COSMAC response regardless of the program 
currently in progress, suspending operation of that pro- 
gram and allowing real-time response. Use of DMA pro- 
vides the quickest response with least disturbance of the 
program. 

A two-bit st3te code and two timing lines are pro- 
vided for use by I/O device circuits. These four signals 
permit synchronization of I/O circuits with internal 
CDP1802 operating cycles. The state code indicates 
whether the CDP1S02 is responding to a DMA request, 
responding to an interrupt request, fetching an instruc- 
tion, or 'executing an instruction. The timing signals 
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are used by the memory and I/O systems to signal a 
new processor state code, to latch memory address bits, 
to take memory data from the bus, and to set and reset 
I/O controller flip-flops. 

Bytes are transmitted to and from memory by means 
of the common data bus. The CDP1802 provides two 
lines to control memory read/write cycles. During a 
memory write cycle, the byte to be written appears on 
the data bus, either from the CPU or from an I/O device, 
and a memory write pulse is generated by the CPU at the 
appropriate time. During a memory-read cycle, a 
memory read level output is generated which is used by 
the system to gate the memory output byte onto the 
common data bus for use by the CPU or by an I/O 
device. 

The CDP1802 provides eight memory address lines. 
These eight lines supply 16-bit memory addresses in the 
form of two successive 8-bit bytes. The more significant 
(high-order) address byte appears on the eight address 
lines first, followed by the less significant (low-order) 
address byte. The number of high-order bits required to 
select a unique memory byte location depends on the 
size of the memory. For example, a 4096-byte memory 
would require a 12-bit address. This 12-bit address is ob- 
tained by combining 4 bits from the high-order address 
byte with the 8 bits from the low-order address byte. 
One of the two CDP1802 timing pulses may be used to 
strobe the required high-order bits into an address latch 
(register) when they appear on the eight address lines. 
Latch circuits are not required at all if address registers 
are incorporated on the memory chips, as in the RCA 
1800-series ROM's. An internal CPU register holds the 
eight low-order address bits on the address lines for the 
remainder of the memory cycle. 

Four additional lines complete the microprocessor 
system interface. A single-phase clock input determines 
operating speed. The external clock may be stopped and 
started to synchronize the CDP1802 operation with 
system circuits if desired. C onstru ction of the clock 
circuit is simplified by use of XTAL input. A crystal is 
connected between XTAL and clock input; no active 
components are needed. The clear input line initializes 
the microprocessor, and its release starts instruction exe- 
cution. The wait line suspends the CPU operation clean- 
ly. Simultaneous assertion of clear and wait puts the 
CPU in a program load mode. 

COSMAC Architecture and Notation 

Fig. 2 illustrates the internal structure of the 
COSMAC Microprocessor CDP1802. This simple, unique 
architecture results in a number of system advantages. 
The COSMAC architecture is based on a register array 
comprising sixteen general-purpose 16-bit scratch-pad 
registers. Each scratch-pad register, R, is designated by 
a 4-bit binary code. Hexadecimal (hex) notation will be 
used here to refer to 4-bit binary codes. The 16 hexa- 
decimal digits (0,1,2,...E,F) and their binary equivalents 
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Fig. 2 - Internal structure of the CDP J 802 Microprocessor. 



(0000 ,0001, 00 10.....1 110,1 111) are listed in Appendix 
A. 

Using hex notation, R(3) refers to the 16-bit scratch- 
pad register designated or selected by the binary code 
0011. R(3).0 refers to the low-order (less significant) 
eight bits or byte of R(3). R(3).l refers to the high-order 
(more significant) byte of R(3). 

Three 4-bit registers labeled N, P, and X hold the 
4-bit binary codes (hex digits) that are used to select 
individual 16-bit scratch-pad registers. The 16 bits con- 
tained in a selected scratch-pad can be used in several 



ways. Considered as two bytes, they may be sequen- 
tially placed on the eight external memory address lines 
for memory read/write operations. Either byte can also 
be gated to the 8-bit data bus for subsequent transfer 
to the D register. The 16-bit value in the A register can 
also be incremented or decremented by 1 and returned 
to the selected scratch-pad register to permit a scratch- 
pad register to be used as a counter. 

The notation R(X), R(N), or R(P) is used to refer to 
a scratch-pad register selected by the 4-bit code in X, N, 
or P, respectively. Fig. 3 illustrates the transfer of a 
scratch-pad register byte, designated by N, to D. The 
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Fig. 4 -Transfer of data from memory to the D register. 



(right half of Fig. 3) 



lefi Jf of Fig. 3 illustrates the initial contents of vari- 
ous registers (hex notation). The operation performed 
can be written as 

R(N)0 -> D 

This expression indicates that the low-order 8 bits 
contained in the scratch-pad register designated by the 
hex digit in N are to be placed into the 3-bit D register. 
The designated scratch-pad register is left unchanged. 

The right half of Fig. 3 illustrates the contents of the 
CDP1S02 registers after this operation is completed. 
The following sequence of steps is required to perform 
this operation: 

1) N is used to select R. (left half of Fig. 3) 

2) R(N) is copied into A. 

3) A.O is gated to the bus. 

4) The bus is gated to D. 

Memory or I/O data used in various COSMAC opera- 
t; are transferred by means of the common data bus. 
Memory cycles involve both an address and the data 
byte itself. Memory addresses are provided by the con- 
tents of scratch-pad registers. An example of a memory 
operation is 

M(R(X)) -* D 

This expression indicates that the memory byte 
addressed by R(X) is copied into the D register. Fig. 4 
illustrates this operation. The following steps are 
required: 

1) X is used to select R. 

2) R(X) is copied into A. 

3) A addresses a memory byte. 

4) The addressed memory byte 
is gated to the bus. 

5) The bus is gated to D. 

Reading a byte from memory does not change the con- 
tents of memory. 

The 8-bit arithmetic-logic unit (ALU in Fig. 2) per- - 
forms arithmetic and logical operations. The byte stored 
in the D register is one operand, and the byte on the bus 
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(obtained from memory) is the second operand. The re- 
sultant byte replaces the operand in D. A single-bit 
register data flag (DF) is set to "0" if no carry results 
from an add or shift operation. DF is set to "1" if a 
carry does occur. During subtraction, DF = if the sub- 
trahend is larger than the minuend, indicating that a bor- 
row has occurred. The 8-bit D register is similar to the 
accumulator found in many computers. 

The internal flip-flop Q can be set or reset by instruc- 
tions, and can be sensed by conditional branch instruc- 
tions. The state of Q is also available as a microprocessor 
output. 

Instruction Format 

COSMAC operations are specified by a sequence of 
instruction codes stored in external memory. A one-byte 
instruction format is applicable for most instructions. 
Two 4-bit hex digits contained in each instruction byte 
are designated as I and N, as shown in Fig. 5. 

For most instructions, the execution requires two 
machine cycles. The First cycle fetches or reads the 
appropriate instruction byte from memory and stores 
the two hex instruction digits in registers I and N. The 
values in I and N specify the operation to be performed 
during the second machine cycle. I specifies the instruc- 
tion type. Depending upon the instruction, N either 
designates a scratch-pad register, as illustrated in Fig. 3, 
or acts as a special code, as described in more detail 
below. 
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Fig. 5 — One-byte instruction format. 



12 



User Manual for the RCA CDP1802 COSMAC Microprocessor 









ADDRESS 


M 


02 


97 


46 


02 


93 


F4 


02 


99 


56 


03 


9A 


17 



A 


02 


98 






RIOi 






R[l l 


02 


98 


R(2) 






R(3) 







N 


6 


P 


1 


X 


7 


1 


4 



DF • ■ 



D - 



0> 



ADDRESS 


M 


02 


97 


46 


02 


93 


F4 


02 


99 


56 


02 


9A 


17 



A 


02 


98 






N 


4 










P 


1 
























X 


7 
















RIOI 










* 1 


F 
















Rill 


02 


99 






ALU 














R(2I 








DF 








BO) 
















F4 



Fig. 6 — Typical instruction fetch cycle. 



Instructions are normally executed in sequence. A 
program counter is used to address successively the 
memory bytes representing instructions. ;!n the 
COS.MAC architecture, any one of the 16-bit scratch-pad 
registers can be used as a program counter. The value of 
the hex digit contained in register P determines which 
scratch-pad register is currently being used as the pro- 
gram counter. The operations performed by the instruc- 
tion fetch cycle are 

M(R(P))-> I,N;R(P)+] 

Fig. 6 illustrates a typical instruction fetch cycle. 
Register P has been previously set to 1 , designating R(l) 
as the current program counter. During the instruction 
fetch cycle, the "0298'" contained in R(P) is placed in A 
and used to address the memory. The F4 instruction 
byte at M (0298) is read onto the bus and then gated 
into 1 and N. The vaJue in A is incremented by 1 and 
replaces the original value in R(P). The next machine 
cycle will perform the operation specified by the values 
in I and N. Following the execute cycle, another instruc- 
tion fetch cycle will occur. R(P) designates the next in- 
struction byte in sequence (56). Alternately repeating 
instruction fetch and execute cycles in this manner 
causes sequences of instructions that are stored in 
memory to be executed. 

Although most of the program instructions have a 
one-byte format, some are two or three bytes in length. 

The immediate and short-branch instructions have a 
two-byte format, as shown in Fig. 7. For example, the 
instruction "30" followed by "45" will execute an 
unconditional branch to the address 45 on the current 
page; the instruction "FC" followed by "22" will exe- 
cute an immediate add operation in which the operand 
22 is added to the second operand from the D register. 



The long-branch instructions have a thrce-byte for- 
mat, as shown in Fig. 8. When the instruction "C32F9A" 
is encountered, a conditional long-branch operation is 
performed. In this case, if the DF flag is set, a long 
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Fig. 8 — Three-byte format for long-branch instructions. 

branch to the address 2F9A is executed. If DF is not set, 
the next instruction in sequence is executed (the one fol- 
lowing 9 A). 

The long-skip instructions are one byte anil require 
no address bytes (as the long-branch instructions do). 
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Fig. 7 — Two-byte instruction format. 



However, the unconditional long-skip and long-skips 
with test conditions met will, in effect, have the instruc- 
tion format shown in Fig. 9. 

If the test conditions are met, the two bytes are 
skipped. If the test condition is not satisfied, execution 
continues at the first byte following the operation code. 
For a summary of instructions and formats, see Appen- 
dix A. 



Timing 

The CPU machine cycle during which an instruction 
byte is fetched from memory is called state (SO). The 
cycle during which the instruction is executed is called 
state 1 (SI). During execution of a program, the 
CDP1802 generally alternates between SO and SI, as 
shown in Fig. 10. Each machine cycle (SO or SI) is in- 
ternally divided into eight equal time intervals, as illus- 
trated in the section on Timing Diagrams. Each time 
interval is equivalent to one cycle (T). The rate at which 
machine cycles occur is, therefore, one eighth of the 
clock frequency. The instruction time is 16T for two 
machine cycles, and 24T for three machine cycles. 

The majority of instructions require the same fetch/ 
f cute time. The only exceptions are the long-branch 
ou. . long-skip instructions. These instructions require 
two machine cycles for execution. The instruction cycle 
in these cases contains three machine cycles (one fetch 
and two execute). The state sequencing will then be as 
shown in Fig. 1 1 . 
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Fig. 10 — Sequence of machine states for norma/ 
instruction cycles. 

R(P) is incremented after its use. Immediate addressing 
allows the user to extract data from the program stream 
without setting up special constant areas in memory and 
pointers to them. Operations ADD IMMEDIATE (FC) 
and LOAD IMMEDIATE (F8) are examples of immedi- 
ate instructions. 

I In stack addressing, one specific CPU register is im- 
plied as the pointer to memory. Often, R(X) is used, and 
in one case R(2) is used. A "stack" is a last -in first-out 
working area in memory used to store intermediate cal- 
culations and to keep track of transfers of control be- 
tween parts of a program. 
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Fig. 11 — Sequence of machine states for long-branch and long-skip instruction cycles. 



Addressing Modes 

There are four basic modes of addressing in the 
LOSMAC architecture: register, register-indirect, imme- 
diate, and stack. 

In register addressing, the address of the operand is 
contained in the four lower-order bits, the N-field, of 
the instruction byte. This addressing mode allows the 
user to directly address any of the: 16 scratch-pad regis- 
ters for the purpose of counting or moving data in or 
out of registers. Typical instructions in this category are 
DECREMENT (2N) and GET LOW (8N). 

Register-indirect addressing is a variant of indirect 
addressing utilizing CPU registers as pointers to memory. 
In this mode, the selected register contains not data, but 
the address of data. A four-bit address in register N will 
specify one of the sixteen scratch-pad registers whose 
contents are the address of data in memory. 

Indirect addressing is the dominant mode in 
COSMAC. It allows the user to address up to 65 kilo- 
bytes of memory with a single one-byte instruction. 

In immediate addressing, R(P) addresses memory so 
that the operand is the byte following the instruction. 



The strength of the COSMAC architecture, and its 
ability to optimize program size and efficiency as com- 
pared with more conventional minicomputer architec- 
tures, lies in these four addressing modes and the liberal 
number of CPU registers. By using stacks for working 
space, immediate addressing for all constants, register 
pointers for tabular and vector arrays, and the registers 
themselves for miscellaneous counters and switches, 
optimal use of program space is made. 



Multiple Program Counters 

A program counter is a register which points to the 
next, instruction to be fetched and executed. COSMAC 
provides the unique capability to specify, in a single 
instruction, any one of the 16 registers as program 
counter. This feature makes it possible to maintain 
pointers to several different programs simultaneously 
and to transfer control quickly from one to another. A 
pointer to a program which services an interrupt request 
is a special and important example of this feature. 
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This section defines each instruction and describes it 
i terms of internal machine operation. Examples are 
»,iven throughout for illustration. The following section. 
Instruction Utilization, covers many of the same instruc- 
ions but from a why, when, and how point of view. For 
xample, this section defines operation of ADD and 
ADD WITH CARRY instructions. The Instruction Utili- 
sation section discusses how these instructions apply and 
nteract in multiple precision arithmetic. 
I Each CPU instruction is fetched during the SO 
machine cycle and executed during the SI state except 
'ot long-branch and long-skip instructions which require 
wo SI states for execution. The operations performed 
curing the execute cycle Si are determined by the two 
t digits contained in I and N. These operations are 
Mvided into eight genera! classes: 

<! 

Register Operations - This group includes seven in- 
"tructions used to count and to move data between 
Sternal COSMAC registers. 

< Memory Reference - Seven instructions are provided 
Io load or store a memory byte. 

Logic Operations - This group contains ten instruc- 
tions for performing logic operations, 
t 

t Arithmetic Operations - This group contains twelve 
nst/uctions for performing arithmetic operations. 

J 



Branching — Twenty different conditional and un- 
conditional branch instructions are provided. These 
instructions can be subdivided into sixteen short-brunch 
instructions for in-page operation and eight long-branch 
instructions to any location in memory space. 

Skip Operations — Nine conditional and uncondi- 
tional skip instructions are provided covering both shurt- 
and long-skip instructions. 

Control — Ten control instructions facilitate program 
interrupt, operand selection, branch and link operations, 
and control of an output flip-flop. 

I/O Byte Transfer - Seven instructions arc provided 
to load memory and CPU from I/O control circuits, and 
seven instructions to transfer data from memory to I/O 
control circuits. 

Each instruction is designated by its two-digit hex 
code and by a name. A description of the operation is 
provided using the symbolic notation described earlier. 
A two-to-four-letter abbreviated name is also given and 
is used as a mnemonic for assembly language program- 
ming. Examples are shown in this section for most in- 
structions. Note that all the examples illustrate action 
only during the instruction execute cycle, SI. A sum- 
mary of the instruction repertoire is given in Appendix 
A. It should be noted that "68", which is unused, is 
reserved for future use by RCA. It is considered an 
"illegal" code and should not be used. 

i 

j 
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Register Operations 



INC 


INCREMENT REG N 


R(N)+1 

• 


1N 



When 1=1, the scratchpad register specified by the hex digit in N is incremented by l.Note that FFFF-i] 

0000. r. 



I 



A 


02 


FF 






RIOI 


03 


7A 


Sill 


01 


32 


ai2i 






RI3I 


02 


FF 





U 


3 


P 





X 


2 


1 


1 








ALU 




OF - 









AB 



[>T 





1 02 








N 


3 


A 














P 













X 


2 














RIO) 


03 


7A 






1 


1 








R|l) 


01 


32 






ALU 




RI2) 








OF - 






R(3I 


03 


00 









A8 



Fig. 12 - Example of instruction 1N - INCREMENT R(N). 



DEC 


DECREMENT REG N 


R(N)-1 


2N 



I 

i. 



I 

L 



r 



1 



I 

L 



t 



When 1=2, the register specified by N is decremented by 1. Note that 0000-l=FFFF. 



fi 1 
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01 


32 






RIOI 


03 


78 


R|1l 


01 


32 


R(2) 






RI3I 


03 


00 



N 


1 


P 





P< 


2 


1 


2 



OF 



A8 



H A h 1 



32 



-1 

ON 



RIOI 


03 


7B 


R(1l 


01 


31 


RI2) 






RI3) 


03 


00 



OF 



N 


i 


P 





X 


2 




2 




H- 1 




■ 


AS 



13 - Example of instruction 2N - DECREMENT R(N). 



IRX 


INCREMENT REG X 


R(X)+1 


60 



When 1=6 and N=0, the scratch-pad register specified by the hex digit in X is incremented by 1. 



+i 



| A | 02 


70 






RIO) 


03 


78 


Rill 


01 


32 


R(2) 


C2 


70 


RI3) 


03 


00 



N 





P 





X 


2 


1 


6 



ALU 



OF - — 

HE] 



:> 



I 02 H 



RIOI 



RID 



R(2) 



R|3) 



03 



02 



03 



7E 



00 



N 





P 





X 


2 




6 



HE] 



Fig. 14 - Example of instruction 60 - INCREMENT R(X). 
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Instruction Repertoire 



i H 



GLO 



GET LOW 



R(N).0-> D 



. When 1=8, the low-order byte of the register specified by N replaces the byte in the D register. 
I 



AO 





01 


31 








1 


\ ' 






N 










P 













X 


2 












8 


RIO) 


03 


7C 






1 








Rll! 


01 


31 






ALU 




fll2» 








OF- 






R(j| 


03 


OC 









AS 



31 



AO 



j 1 A~ Ql I 31 



RIO) 


03 


7C 


Rill 


01 


31 


RI2) 






R(3l 


03 


00 





N 






1 




P 







X 


2 






8 








ALU 


' 1 


OF - 











31 



31 



Fig. 15 - Example of instruction SN - GET LOW. 



1 When I=A, the byte contained in the D register re- 
places the lew-order byte of the register specified by N. 



The contents of D are not changed. 



ii 



13 



U3 



RIOI 


03 


7E 


RID 


01 


31 


3f 21 


00 


00 


RI3l 


72 j 00 



N 


2 


P 





X 


2 


1 


A 



ALU 



72 



JUL 



i) 



RIO) 


03 


7E 


phi 


01 


31 


RI2I 


00 


72 


RI3) 


72 


oo 


t 



N 


2 


P 





X 


2 


1 


A 



Of 



72 



Fig. 16 - Example of instruction AN - PUT LOW. 



i 



17 



8N 



PLO 


PUT LO 


D -* R(N).0 


AN 



GHI 


GET HI 


*R(N).1 -* D 


9N 



^ When 1=9, the high-order byte of the register speci- fied by N replaces the byte in the D register. 

3SE 



D3 



A 


72 


OC, 






RIOI 


03 


7D 


Rll) 


01 


31 


RI2I 






RI3I 


72 


00 



N 


3 


P 





X 


2 




9 



HI 



Of i 



d 



72 



A.I 

dT 



RIOI 


03 


7D 


Rll) 


01 


31 


RI7I 






RI3I 


72 


00 


72 



N 


3 


P 





X 


2 




9 



ALU 



OF 



(Z 



Fig. 17 - Example of instruction 9N - GET HIGH. 
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PHI 


PUTHI 


D->R(N).1 


BN 


4en I=B, the byte contained in the D register re- 


The contents of D are not changed. 





places the high-order byte of the register specified by N. 



F!!0) 


03 


7F 


fill) 


01 


3! 


R|2) 


00 


72 


«3I 


72 


00 



N 


2 


P 





X 


2 


1 


B 



| D | 66 [ -»• 



66 



TUB 



RIO) 


03 


7F 


R(ll 


01 


31 


R(2) 


66 


72 


R(3i 


72 


00 



I 



N 


2 


P 





X 


2 


1 


8 



66 



Fig. 18 - Example of Instruction BN - PUT HIGH. 

Memory Reference 



■L0N 



LOAD VIA N 



M{R(N))- D;N^0 



ON 



E 



I i 



I - 

i ! 



When 1=0 and N is different from 0, the external 
memory byte addressed by the contents of the register 



specified by N replaces the byte in the D register. The 
contents of memory are not changed. 



T 



00 



ADDRESS 


M 








00 


17 


12 






RlOl 


01 


00 


00 


IS 


34 






RID 


00 


19 


00 


19 


56 






R(2) 


00 


17 


00 


1A 


78 






RI3I 







19 



N 


1 


P 





X 


2 


1 






DF = - 



-c 
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12 
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34 
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00 


19 


00 


19 


56 
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17 


00 


1A 


78 


R(3| 







N 


1 
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X 


2 








OF* 



56 



56 



Fig. 19 - Example of instruction ON - LOAD VIA N. 



I 



I 

1. 



LDA 


LOAD ADVANCE 


M(R(N)J -* D; R(N)+1 


4N 



When 1=4, the externa] memory byte addressed by 
the contents of the register specified by N replaces the 
byte in the D register. The original memory address con- 
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17 


12 






RIO) 


01 


00 


00 


18 


34 






Rill 


00 


19 


00 


19 


56 






R12) 


00 


17 


00 


1A 


78 






RI3I 1 - 





N 


1 


P 





X 


2 


1 


4 




ALU 






° 


"1 



tained in R(N) is incremented by 1. The contents of 
memory are not changed. 
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01 


CO 


00 
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19 
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17 


00 


1A 
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56 



Fig. 20 - Example of instruction 4N - LOAD ADVANCE. 
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1 
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19 



LDX 


LOAD VIA X 


M(R(X)) ->D 





1 When I=F and N=0, the memory byte addressed by 
the contents of the rcrister specified by X replaces the 
'byte in the D register. (This instruction does not incre- 



ADDRESS 


M 


00 


30 


01 


00 


31 


00 


CO 


32 


92 


00 


33 


57 



F 



1 « 


I" 


32 






N 













f> 













X 


2 










1 




h7o' 


00 


70 






F 








Bin 


00 


33 






AUJ 




R(I> 


00 


32 




DF 






R(3l 













00 



ment the address as LOAD ADVANCE does.) The con- 
tents of memory are not changed. 







92 



32 



AODRESS 


M 








00 


30 


01 






RIO) 


00 


70 


00 


3! 


00 


Rin 


00 


33 


00 


32 


92 


R(2) 


00 


32 


00 


33 


57 


RI3I 







Fig. 21 - Example of instruction FO - LOAD VIA X. 



N 





P 





X 


2 


1 


F 



DF ■ 



92 



LDXA 


LOAD VIA X AND ADVANCE 


M(R(X)) -+ D; R(X) + 1 


72 



When 1=7 and N=2, the externa] memory byte ad- 
I dressed by the contents of the register specified by X 
replaces the byte in the D register. The original memory 



address contained in R(X) is incremented by I. The con- 
tents of memory are not changed. 
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P 





X 
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1 


7 
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00 17 



AOORESS 


M 
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17 
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18 
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19 
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1A 
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X 
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1 
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Fig. 22 - Example of instruction 72 - LOAD VIA X AND ADVANCE. 



LDI 


LOAD IMMEDIATE 


M(R(P)) ~> D; R(P)+1 


F8 



t 



When I=F and N=8, the memory byte immediately 
following the current instruction byte replaces the byte 
in D. Because the current program counter represented 
by R(P) is incremented again by 1 during the execution 
of this instruction, the instruction byte following the 
immediate byte placed in D will be fetched next. 

The use of immediate data is a useful way to avoid 



setting up special constant areas in memory and pointers 
to them. 

This instruction is one of five which load D from 
memory. It uses R(P) as a pointer, while LDA and LDN 
use R(N) and LDX and LDXA use R(X). LDI, as well as 
LDA and LDXA, increments the pointer after use, but 
LDX and LDN do not. 
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03 





M 








03 


27 


F8 






R(0l 


03 


28 


03 


2S 


92 






RID 


00 


71 


03 


29 


F9 






Rl2) 


00 


33 


03 


2A 


57 






ROl 
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OF 



N 


8 


P 





X 


2 


1 


F 




ALU 






D 


21 
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M 


03 


27 
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03 


28 
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03 


29 


F9 


03 


2A 


57 
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03 


29 
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RI1I 


00 


71 
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33 


RI3I 
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1 
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ALU 



OF - - 
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S2 



Fig. 23 - Example of instruction F8 - LOAD IMMEDIATE. 



STR 


STORE 


D -* M(R(N)) 


5N 



When 1=5, the byte in D replaces the memory byte 



addressed by the contents of the register specified by N. 
The contents of D are not changed. 
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78 
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2 
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X 


2 
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OF - - 
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M 


CO 


17 
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34 


00 


19 


56 


00 


1A 
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00 


17 










RIO) 


01 


01 




R|l) 


00 
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00 


17 
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X 
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1 
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OF - — 



I ° 1 56 V* 



56 



Fig. 24 — Example of instruction 5N — STORE. 



STXD 


STORE VIA X AND DECREMENT 


D-M(R(X)); R(X)-1 


73 



When 1=7 and N=3, the byte in D replaces the 
memory byte addressed by the contents of the register 
specified by X. The original memory address contained 



I 



-en 



CO 
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17 


12 






RIOI 


01 


00 
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18 


34 






Rill 


00 


19 


00 


IS 


S6 






RI2I 


00 


17 


00 


1A 


78 






RI3I 







F5 



17 



N 


3 


P 





X 


2 


1 


7 



DF - - 



[ O | F5 | — * 



in R(X) is decremented by i. The contents of D are not 
changed. 
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1 P I F5 I ~" 
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Fig. 25 - Example of instruction 73 - STORE VIA X AND DECREMENT. 
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.21 



n 



Logic Operations 



1 1 In general, R(X) or R(P) points to one operand, D is 
the other, and the result replaces the latter in the D 

: I egister. When R(X) is used as the pointer, the X register 
nust have been previously loaded (by an instruction 
SET X described among the control instructions). If 



P 
1 1 



R(P) is used as the pointer to the operand, it points to 
the byte in memory after the instruction, called the 
immediate byte. The use of immediate data is a simple 
way of extracting data directly from the instruction 
sequence. 



OR 


OR 


! M(R(X)) ORD^D 


F1 



When I=F and N=l, the individual bits of the two 8- 
;Dit operands are combined according to the rules for 
logical OR as shown to the right. The byte in D is one 
operand. The memory byte addressed by R(X) is the 
second operand. The result byte replaces the D operand. 
This instruction can be used to set individual bits. 
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D 




OR 
















1 




1 


1 







1 
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Fig. 26 - Example of instruction F1 - OR. 
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32 
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00 


33 


57 
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N 


1 


P 





X 


t 


1 


F 




ALU 


OR 


- 




07 j 



ORI 


OR IMMEDIATE 


M(R(P))ORD->D;R(P)+1 


F9 



I When I=F and N=9, a logical OR operation is per- 
formed similar to Fl. The D byte is one operand, and 
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ALU 
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D 
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the memory byte immediately following the F9 instruc- 
tion is the second operand. The result goes to D. 
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Fig. 27 - Example of instruction F9 - OR IMMEDIATE. 
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XOR 


EXCLUSIVE-OR 


M(R(X)) XOR D 


F3 



When I=F and N=3, the individual bits of the two 8- 
bit operands are combined according to the rules for 
logical EXCLUSIVE-OR as shown to the right. The D 
byte and M(R(X)) are the two operands. The result byte 
replaces the D operand. This instruction can be used to 
compare two bytes for equality since identicaJ values 
will result in all zeros in D. 
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Fig. 28 - Example of instruction F3 - EXCLUSIVE-OR. 



XRI 


EXCLUSIVE-OR IMM. 


M(R(P)) XORO->D; R{P)+1 


FB 



a 



When I=F and N=B, an EXCLUSIVE-OR operation 
similar to F3 is performed. The D byte is one operand, 
and the memory byte immediately following the FB 



instruction is the second operand. This instruction can 
be used to complement the D register when the immedi- 
ate byte is "FF". 
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Fig. 29 - Example of instruction FB - EXCLUSIVE-OR IMMEDIATE. 



AND 


AND 


M(R(X)) ANDD^O 


F2 



When I=F and N=2, the individual bits of the two 8- 
bit operands are combined according to the rules for 
logical AND as shown to the right. The byte in D is one 
operand. The memory byte addressed by R(X) is the 
second operand. The result byte replaces the D operand. 
This instruction can be used to test or mask individual 
bits. 
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Fig. 30 — Example of instruction F2 — AND. 











ANI 


AND IMMEDIATE 


1 1 1 

M(R(P)) AND D-^D; R(P) + 1 


FA 


1 .... 



s When I=F and N=A, a logical AND operation is per- the memory byte immediately following the FA instruc- 
- '.formed simibr to F2. The D byte is one "operand, and tion is the second operand. 
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Fig. 31 - Example of instruction FA - AND IMMEDIATE. 



SHR 


SHIFT RIGHT 


SHIFT D RIGHT; LSB(D) -» DF, -» MSB(D) 


F6 



When I=F and N=6, the 8 bits in D are shifted right 
one bit position. The original value of the low-order D 
j)it is placed in DF. The final value of the high-order D 



bit is always "O". This instruction can be used to test 
successive bits of the operand or to divide by 2. 
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Fig. 32 - Example of instruction F6 - SHIFT RIGHT. 
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SHRC 


SHIFT RIGHT WITH CARRY 






RSHR 


RING SHIFT RIGHT 


SHIFT D RIGHT; LSB(D) ■+ DF. DF -* MSB(D) 


76 



When 1=7 and N=6, the contents of the D register 
are shifted one bit position to the right. The low-order 
bit of the D register becomes the carry bit (DF), while 



the carry bit becomes the high-order bit of the D 
register. 

Either mnemonic may be used for this instruction. 
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Fig. 33 - Example of instruction 76 — SHIFT RIGHT W/TH CARRY. 



SHL 


SHIFT LEFT 


SHIFT D LEFT; MS8(D) -* DF, -* LSB(D) 


FE 



When I=F and N=E, the 8 bits in D are shifted left 
one bit position. The original value of the high-order 
D bit is placed in DF. The final value of the low-order 



D bit is always "0". This instruction can be used to test 
successively bits of the operand or to multiply by 2. 
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Fig. 34 - Example of instruction FE - SHIFT LEFT. 
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SHLC 
RSHL 


SHIFT LEFTWITH CARRY 
RING SHIFT LEFT 


SHIFT D LEFT; MSB(D) -* DF, DF •* LS8{D) 


7E 



' • When 1=7 and N=E, the contents of the D register 
'■sz shifted one bit position to the left. The high-order 
•oit of the D register becomes the carry bit (DF), while 



it 



11 



Btfort SHLC: 



After SHLC: 



the carry bit becomes the low-order bit of the D register. 
JEijhermnemonic may be used for this instruction. 
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Fig. 35 - Example of instruction 7E - SHIFT LEFT WITH CARR Y. 



J 



J 



Arithmetic Operations 



This group provides the operations ADD, SUB- 
TRACT, and REVERSE SUBTRACT. The three basic 
instructions arc augmented with instructions to handle 
{mmediate data, data with carry or borrow, and immedi- 
ate data with carry or borrow. 



In general, R(X) is the pointer to one operand in 
memory. The other operand is found in D. For immedi- 
ate data, R(P) is used as the pointer and addresses the 
byte in memory after the instruction, called the immedi- 
ate byte. 



i 



ADD 


ADD 


M(R(X))+D-*DF. D 


F4 



1 When I=F and N=4, two 8-bit operands are added 
'ogether. The D byte and M(R(X)) are the two single- 
byte operands. The 8-bit result of the binary addition 
-eplaces the D operand. The final state of DF indicates 
t/hether or no: a carry occurred. It is independent of the 
original content in DF. 

, Example 1: 3 A + 4B - 85 



D register contains 85, DF contains 

Example 2: 3A + FO = 12A 

D register contains 2A, DF contains I 

The latter example demonstrates overflow. The result is 
too big for the 8-bit register, and a carry is generated. 
DF can be subsequently tested with a branch instruc- 
tion. 
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Fig. 36 - Example of Instruction F4 - ADD. 



ADI 


ADD IMMEDIATE ! 


M(R(P))+D -* DF, D; R(P)+1 


FC 



When I=F and N=C, the two operands are added as in 
F4. The D byte is one operand, and the memory byte 



immediately following the FC instruction is the other 
operand. 
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Fig, 37 - Example of instruction FC - ADD IMMEDIA TE. 



ADC 


ADD WITH CARRY 


M(R(X))+D+DF -> DF, D 


74 



When 1=7 and N=4, the specified byte plus the con- 
tent of DF are added to the contents of the D register. 
The 8-bit result of the binary addition replaces the D 



operand. DF will indicate if the addition generated a 
carry. 
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Fig. 38 - Example of instruction 74 - ADD WITH CAFtRY. 
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Example 1 : 

Byte in memory: 
D register contains: 
DF contains: 
Result: 
After additioji: 

D contains: 
DF contains: 



3A = 00111010 
2D = 00101101 

1 

68 = 01101000 



01101000 


The ADD WITH CARRY instruction is useful when 
tnultibyte words are to be added. In the sample above, 
"J wo 8-bit words were first added (not shown) and gener- 
_j ited a carry which must be included in the next higher- 
order byte addition as shown below. For instance add: 

"* 3AF0 
j + 2D20 



Example 2: 

Byte in memory: 
D register contains: 
DF contains: 
Result: 
After addition: 

D contains: 
DF contains: 



C2 - 11000010 
3D = 00111101 

. r 

100=1 00000000 
00000000 

1 



Similarly to Example 1, the following operations 
were performed: 
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+ 20 
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DF =^oJ 68 DF = 10 
Final result: DF = 6810 



C2 
+ 3D 

DF =jj 00 DF = 1 [ 

Final result: DF = 1 



Dl 

+ 33 
04 
0004 



1 ADCI 


ADD WITH CARRY, IMMEDIATE 


M(R(P))+D + DF -» DF. D R(P) + 1 


it 



hen 1=7 and N=C, the specified byte in memory 
the content of the carry bit is added to the con- 



tents of the D register. The final state of DF indicates 
whether or not a carry occurred. 
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Fig. 39 - Example of instruction 7C - ADD WITH CARR Y, /MM ED I A TE. 
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so 


SUBTRACT D 


M(R(X))-D-*DF.D 


F5 



When I=F and N=5, the byte in D is subtracted from 

'lie memory byte addressed by R(X). The 8-bit result 

replaces the subtrahend in the D register. Subtraction is 

2's complement: each bit of the subtrahend is comple- 

-fnented and the resultant byte added to the minuend 

'plus I. The final carry of this operation is stored in DF: 

DF=0 indicates a borrow 

DF=1 indicates no borrow 
_ . . .. .. 



Example 1: 42-0E=42 + Fl + 1 = 134 
D register contains 34, DF contains I. (No borrow) 

Example 2: 42 - 42 = 42 + BD + 1 = 100 
D register contains 00, DF contains 1. (No borrow) 

Example 3: 42 - 77 = 42 + 88 + 1 = CB 
D register contains CB, DF contains 0. (Borrow) 
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A final value of "0" in DF indicates a borrow and 
that the subtrahend was larger than the minuend. The 
answer is negative, but in 2's complement form: taking 
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the 2's complement of CB and assigning a minus sign 
provides the correct answer (42 - 77 = -35). fi 
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Fig. 40 - Example of instruction F5 - SUBTRACT D. 



SOI 


SUBTRACT D IMMEDIATE 


M{R{X))-D-+DF,D; R{P)+1 


FD 



When I=-F and N=D, the two operands are subtracted 
as in F5. The D byte is the subtrahend, and the memory 
byte immediately following the FD instruction is the 
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minuend. The Final value in DF indicates whether or not 
a borrow occurred. 
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Fig. 41 - Example of instruction FD - SUBTRACT D IMMEDIATE. 



SDB 


SUBTRACT D WITH BORROW 


M(R(X))-D-{NOT DF) -+ DF, D 


75 
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When 1=7 and N=5, the byte in D with a borrow-in 
from a previous operation is subtracted from the mem- 
ory byte addressed by R(X). The 8-bit result replaces the 
subtrahend in the D register. A Final borrow is comple- 
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mented and stored in DF. Subtraction is performed by 
complementing each bit of the D register and adding it, 
with the carry-in from a previous operation, to the minu- 
end. 
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Fig. 42 - Example of instruction 75 - SUBTRACT D WITH BORROW. 
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J. 

The SUBTRACT D WITH BORROW instruction is 
^oplicable when multibyte words are subtracted. The 
>llowing examples assume that two bytes have been 

i E 



29 



subt racted generating a borrow which must be included 
in the next higher-order byte subtraction. Four alterna- 
tives are possible in the subtraction of two words: 



n 

y 



J 



CONDITION I: DF = 0, i.e. Borrow = 1 

Borrow is present from a preceding carry 

Case I M(R(X))>D 

Example: 

M(R(X» - 40 

40-20-1 = 40 + DF+0 = I IF 
After addition: 

D register contains IF ! 

DF contains 1 (Borrow = 0) 



Case 2 M(R(X))<D 
Example: 

M(R(X)) = 4A 

: D = C1 . . 

4A - CI -1 = 4A + 3E + = 88 

After addition: 

D register contains 88 

DF contains (Borrow = 1) 



t: 
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CONDITION II: 



DF= 1, i.e. Borrow = 

No borrow is present from a preceding carry 



Case 3 M(R(X))>D 

Example: 

M(R(X)) = 64 
D =32 

64 -32-0 = 64 + CD+ 1 = 132 

After addition: 

D register contains 32 

DF contains 1 (Borrow = 0) 



Case 4 M(R(X))<D 

Example: 

M(R(X)) = 71 
D = F2 

71 -F2-0 = 71 +0D+ 1 =7F 

After addition: 

D register contains 7F 

DF contains (Borrow = 1) 



In Cases 2 and 4, the answer is a negative number and in 2's complement notation. 
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M(R(P))-D-(NOT DF) -*■ DF, D; R{P)+1 
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IMMEDIATE 







( When 1=7 and N=D, the two operands and borrow are 
.'.ntracted as in instruction 75. The memory byte imme- 
diately following the 7D instruction is the minuend. To 
tha minuend is added the complement of the contents in 
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D plus the carry-in in DF from a previous operation. The 
8-bit result replaces the contents of the D register and a 
final borrow is complemented and stored in DF. The 
program counter is also incremented by 1. 
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Fig. 43 - Example of instruction 7D - SUBTRACT D WITH BORROW, IMMEDIA TE. 
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SM 


SUBTRACT MEMORY 


D-M{R(X)) -> DF, D 


F7 



When I=F and N=7, the memory byte addressed by 
R(X) is subtracted from the byte in D. The result byte 
replaces the minuend in D. This operation is identical to 
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F5 with the operands reversed. A final borrow is comple- 
mented and stored in DF. 
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Fig. 44 - Example of instruction F7 - SUBTRACT MEMORY. 



SMI I SUBTR ACT MEMORY IMMEDIATE 



D-M(R(P)) ■* DF, D; R(P)+1 



FF 



When 1=F and N=F, the two operands are subtracted 
as in F7. The D byte represents the minuend, and the 
memory byte immediately following the FF instruction 



represents the subtrahend. (This instruction is equivalent 
to FD with the operands reversed.) A final borrow is 
complemented and stored in DF. 
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Fig.. 45 - Example of instruction FF - SUBTRACT MEMORY IMMEDIATE. 
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SUBTRACT MEMORY WITH BORROW 



D-M(R(X))-(NOT DF) -* DF. D 
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When 1=7 and N=7, the byte in memory addressed by 
R(X) plus the borrow (indicated by DF=0) is subtracted 
from the byte in the D register. This operation is similar 
to the instruction 75 but with the operands reversed. 
The 8-bit result replaces the minuend in D, and DF=0 



will indicate if a final borrow occurred. Subtraction 
takes place by complementing the memory byte ad- 
dressed by R(X) and adding it with the contents of DF 
to the minuend in D. 



ADDRESS 


M 








00 


30 


18 






RIO) 


00 


71 


00 


31 


25 






RID 


00 


33 


00 


32 


CI 






RI7) 


00 


32 


00 


33 


64 






RI3I 







DF 



N 


7 


P 


1 


X 


2 


1 


7 




ALU 


l-l 


- 


D 


4A 



00 



ADDRESS 


M 








00 


30 


IB 






RIO) 


00 


71 


00 


31 


2S 


RID 


00 


33 


00 


32 


CI 


RI2I 


00 


32 


00 


33 


64 


RI3I 







N 


7 


P 


1 


X 


2 


1 


7 



l-l 



DF -0 



CI 



Fig. 46 - Example of instruction 77 - SUBTRACT MEMOR Y WITH BORROW. 



Instruction Repertoire 



31 



SM3I 


SUBTRACT MEMORY WITH BORROW, 
IMMEDIATE 


D-M{R(P)) T (NOT DF) -* DF, D R(P}+1 


7F 



■ When 1=7 and N=F, the two operands and borrow 
" '.re subtracted as in instruction 17 The immediate byte 
in memory following the instruction 7F plus the borrow 
the subtrahend, and the contents of D is the minuend. 

- 1 



1 



ADDRESS 


V 


00 


* 


18 


CO 




7F 


03 


12 


F2 


00 


23 


64 



A 1 00 










00 


32 


BUi 


00 




R!2I 


00 


71 


R(3I 


— 





N 


f 


P 




X 


2 


1 


7 



!-) 



OF - 1 



n 



The 8-bit result replaces the contents of D, and again 
DF=0 indicates that a final borrow was generated. The 
program counter is also incremented by 1 . 



ADDRESS 


M 


00 


20 


18 


ob 


21 


7F 


00 


22 


F2 


00 


23 


64 



+ 1 



00 



22 



RlOl 


00 


32 


ROI 


00 


23 


Fl(2) 


00 


71 


RI3I 






F2 



N 


F 


P 


1 


X 


2 


1 


7 



DF 



ALU 


(-1 


- 







7F 



3 



Fig. 47 - Example of instruction 7F - SUBTRACT MEMORY WITH BORROW, 
IMMEDIATE. 



Branching 



^Short-Branch Operations 

: The current program counter, R(P), normally steps 
sequentially through a list of instructions, skipping over 
lediate data bytes. When 1=3, a short branch instruc- 
tor, is executed. The N code specifies which condition is 
.jsted. If the test is satisfied, a branch is effected by 
changing R(P). 

1 When a branch condition is satisfied, the byte imme- 
diately following the branch instruction replaces the 
lbw-order byte of R(P). Trie next instruction byte will 
be fetched from the memory location specified by the 
*yte following the branch instruction. If the test condi- 
on is not satisfied, then execution continues with the 
instruction following the immediate byte. This ability to 
branch to a new instruction sequence (or back to the 
* eginning of the same sequence to form a loop) is funda- 
mental to stored-program computer usefulness. 

1 



• Because with this instruction only the low-order byte 
of R(P) can be modified, the range of memory locations 
that can be branched to is limited. Since only the low- 
order 8 bits can be modified, short branching is limited 
to 2 s or 256 bytes. Each 256-byte memory segment is 
called a page. Instructions for branching to any location 
in memory are described in the next subsection headed 
"Long-Branch Operations". 

The special case of a short branch instruction and its 
immediate byte occupying the last two bytes in a page is 
treated as follows: If a branch takes place, R(P).l is not 
changed— the branch stays on the same page. If a branch 
does not take place, execution continues at the first 
(Oth) byte of the next page. A branch instruction on the 
last byte of a page always leads into the next page, either 
by branch or by increment. In other words, the address 
of the immediate byte determines the page to which a 
branch takes place. 



BR 


UNCONDITIONAL SHORT BRANCH 


M(R(P)) -+ R(P).0 


30 



I 

When 1=3 and N=0, an unconditional short branch 
J peration is performed. The byte immediately following 



the "30" replaces R(P).0. 



32. 
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ADDRESS 


M 


01 


21 


F6 


01 


22 


30 


01 


73 


82 


01 


54 


2A 



5 



A 


01 


23 






RI0I 






RID 


01 


23 


fl!2) 


00 


37 


RI3I 







N 





P 


1 


X 


2 


1 


3 



DF - - 



- [ A 01 |~23 



I 



ADDRESS 


M 








01 


21 


F6 






RIO) 






01 


22 


30 


Rill 


01 


82 


01 


23 


82 


R(2) 


00 


37 


01 


24 


2A 


R(3I 







82 



I 



u 





p 


1 


X 


2 


1 


3 



FT 



OF • 



Fig. 48 - Example of instruction 30 - UNCONDITIONAL SHORT BRANCH. 



NBR 


NO SHORT BRANCH 


R(P)+1 


38 


SKP 


SHORT SKIP .- 



When 1=3 and N=8, the narne NO SHORT BRANCH 
implies that the byte following the "38" instruction is 
an address which will be skipped. This instruction may 



also be considered to be a SHORT SKIP and is so de- 
scribed in the section on SKIP instructions. 



BZ 


SHORT BRANCH IF D=0 


IF D=0, M(R(P))-+ R(P).0 


32 




ELSE R(P)+1 





When 1=3 and N=2, a conditional short branch opera- 
tion dependent on the value of D is performed. The byte 
in D is examined and if it is equal to zero a branch oper- 
ation is performed. If the value of D is not zero, R(P) is 
incremented by 1. This increment causes the branch 
address byte following the "32" instruction to be 
skipped so that the next instruction in sequence is 
fetched and executed. 

This instruction can be used following one of the 



ALU operations described earlier. For example, an 
EXCLUSrVE-OR operation (F3 or FB) might be used to 
compare an input byte with a byte representing a con- 
stant. A zero result byte in D would represent equality. 
The "32" instruction could then be used to branch to a 
location in the program for handling this value of the 
input byte when D=00, or to proceed to the next in- 
struction in sequence if D^OO, possibly to look for 
equality with other constants. 



en 



ADDRESS 


M 








01 


21 


F8 






RIO) 






01 


22 


32 






Bill 


01 


23 


01 


23 


97 






RI2) 


00 


37 


01 


24 


2C 






RI3) 







N 


2 


P 


1 


X 


2 


1 


3 



OF - - 



01 



ADDRESS 


M 








01 


21 


F6 






RIO) 






02 


22 


32 






RID 


01 


97 


03 


23 


97 






RI2) 


00 


37 


04 


24 


2C 






RI3I 










\ 


97 







23 



N 


2 


P 


1 


X 


2 


1 


3 



ALU 



DF ■ 



CONDITION TRUE 



ADDRESS 


M 








01 


21 


F6 






RIO) 






01 


22 


32 






RID 


01 


23 


01 


23 


97 






R(2) 


00 


37 


01 


24 


2C 






R(3) 







N 


2 


P 


1 


X 


2 


1 


3 



DF - • 







ADDRESS 


M 








01 


21 


F8 






RIO) 






01 


22 


32 






RID 


01 








24 


01 


23 


97 






R(2) 


00 


37 


01 


24 


2C 






RI3I 







N 


2 


P 


1 


X 


7 


1 


3 



OF • 



[ZED 



CONDITION FALSE 



Fig. 49 - Example of instruction 32 - SHORT BRANCH IF D =0 for both falsa and 
true conditions. 



r 



r- 



i 



Instruction Repertoire . 



33 



BNZ 


SHORT BRANCH IF D NOT 


IF D NOT 0, M(R(P)) -* R{P).0 


3A 




ELSE R(P)+1 





, When 1=3 and N=A, a branch is performed only if the 
| /te in D does not equal zero; if it does, the next 



instruction in sequence is executed. 



1 



ADD 




y 


O, 


21 


F5 


01 


23 


3A 




23 


97 


: 


21 


2C 



6 



1 " 


|o, 


23 






N 


A 










P 


1 










X 


2 


BIO) 










t 


3 
















01 


23 






ALU 




R:2I 


00 


37 




OF - 






R(2i 













12 



1°' 1" ! 



ADDRESS 


M 








01 


21 


F6 






RIOl 






01 


22 


3A 






RID 


Ot 


97 


01 


23 


97 






R(2i 


00 


37 


oi ! 


24 


2C 






R!3< 










1 


97 




f 



DF - 



N 


A 


P 


1 


X 


2 


1 


3 




ALU 













Fig. 50 - Example of instruction 3 A - 


SHORT BRANCH IF D NOT 0. 




BDF 


SHORT BRANCH IF DF=1 


IF DF=1, M(R{P)) - R(P}0 




BPZ 


SHORT 8RANCH IF POS OR ZERO 


33 


BGE 


SHORT BRANCH !F EQUAL OR GREATER 


ELSE R(P)+1 





J When 1=3 and N=3, branching occurs if DF=1. Other- 
wise, the next instruction in sequence is performed, 
^■'xamples are not shown for all of the remaining branch 
| structions because they differ only in the condition 



tested. The instruction has three mnemonics useful fol- 
lowing a shift, subtraction, or comparison (by subtrac- 
tion), respectively. 



] 



BNF 

BM 

BL 



SHORT BRANCH IF DF=0 
SHORT BRANCH IF MINUS 
SHORT BRANCH IF LESS 



IFDF=0,M(R{P))-*R(P).0 
ELSE R(Pj+1 



3B 



J' When 1=3 and N=B, a short branch occurs only if 
DF=0. Otherwise, the next instruction in sequence is 



1 



fetched and executed. Again, three mnemonics may be 
useful, all resulting in the same machine action. 



i 



BQ 


SHORT BRANCH IF Q=1 - 


IFQ=1,M(R(P))-> R(P).0 
ELSE R(P)+1 


31 



When 1=3 and N=l, a short branch occurs only if 
Q=l. Otherwise, the next instruction in sequence is 



fetched and executed. 



! 
J 
J 
1 



ADDRESS 


M 


01 


21 


F3 


01 


22 


31 


01 


23 


97 


01 


24 


2C 



[ 4 |« 


23 






RIO) 






RID 


01 


23 


RI21 


00 


37 


RI3I 







N 


1 


P 


1 


X 


2 


1 


3 



ALU 



L7J 



-fTjjrr 



31 



AOORESS 


M 








01 




F6 






RlO) 






01 


22 


31 


Rill 


01 


97 


01 


23 


97 


R!2I 


00 


37 


01 


24 


2C 


RI3I 







N 


1 


P 


1 


X 


2 


1 


3 



Id 



'CD 



CONDITION TRUE 



34 
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01 



23 



address 


M 








ni 


21 


F6 






RIO) 






01 


22 


31 






Rd) 


01 


23 


01 


23 


97 






RI2) 


00 


37 


01 


24 


2C 






RI3I 







N 


» 


P 


1 


X 


2 


1 


3 



JZ1 



ADDRESS 


M 


01 


21 


F6 


01 


22 


31 


01 


23 


97 


01 


24 


2C 



CONDITION FALSE 



s 



01 23 



RIO) 






RID 


01 


24 


RI2I 


00 


37 


RI3I 







N 


1 


P 


1 


X 


7 


1 


3 



ALU 



OF - - 



II 



Fig. 51 - Example of instruction 31 - SHORT BRANCH IF Q = / for both true and 
false conditions. 





BNQ 


SHORT BRANCH IF Q=0 


IFQ=0, M{R(P))-*R(P).0 
ELSE R(P)+1 


39 


When 1=3 and N=9, a short branch occurs only if 
Q=0. Otherwise, the next instruction in sequence is 


fetched and executed. 






B1 


SHORT BRANCH IF EF1 = 1 


IF EF1 = 1, M(R(P)) -+ R(P).0 
ELSE R(P)+1 


34 












BN1 


SHORT BRANCH IF EFi=0 


IF EF1=0, M(R(P)) -+ R(P).0 
ELSE R(P)+1 


3C 












B2 


SHORT BRANCH IF EF2=1 


IF EF2=1,M(R(P))-+ R(P).0 
ELSE R(P)+1 


35 












BN2 


SHORT BRANCH IF EF2=0 


IF EF2=0.M(R(P))- R(P).0 
ELSE R(P)+1 


3D 














B3 


SHORT BRANCH IF EF3=1 


IF EF3=1,M(R(P)) + R(P).0 
ELSE R(P)+1 


36 












BN3 


SHORT BRANCH IF EF3=0 


IFEF3=0. M(R(P))-*R(P).0 
ELSE R(P)+1 


3E 












B4 


SHORT BRANCH IF EF4=1 


IF EF4=1,M(R(P))->R(P).0 
ELSE R(P)+1 


37 












BN4 


SHORT BRANCH IF EF4=0 


IFEF4=0, M(R(P))-> R{P}.0 
ELSE R(P)+1 


3F 



When !=3 and N=4,5,6, or 7, short branching occurs 
only when the corresponding external flag input (EF1, 
EF2, EF3, o r EF 4 ) is h eld in its "tru e" state by external 
circuits (i.e., EF1 , EF2, EF3, or EF4 = or Low). 



When 1=3 and N=CJJ,E, or F, short branching occurs 
only when the corresponding external flag input (EF1, 
EF2, EF3, or EF4) is held in it s "false^state by external 
circuits (i.e., EF1, EF2, EF3, or EF4 = 1 or High). 



Instruction Repertoire 



35 



Long-Branch Operations 

[The long-branch instructions have a two-byte address 
„nd allow branching to any location within the full 



memory space during three machine cycl es (one fetch 
plus two execute). 



I 



LBR 



LONG BRANCH 



M(R(P))-> R(P).1 
M(R(P+1)) - R(P).0 



CO 



;s 



When I=C and N=0, an unconditional long branch is 
performed. The two bytes in memory following the 
operation code replace the full 16-bit contents of R(P). 

1 



If, for instance, the instruction C0253A has been exe- 
cuted, the next instruction will be found at memory 
location 253A. 



£ 



OT 



ADDRESS 


M 










00 


30 


CO 






R(0| 


01 


35 


00 


3; 


25 


RIM 


01 


75 


00 




3A 


R(2> 


00 


31 


oo 


33 


62 


Rt3i 







N 





P 


2 


X 


1 


1 


c 



ALU 



HZ 



oo 



31 



ADDRESS 


M 








00 


30 


CO 






R(0) 


01 


35 


00 


31 


25 






RID 


01 


75 


00 


32 


2A 






RI2I 


25 


3A 


00 


33 


62 






RI3I 












3A 


25 


f 



N 





f> 


2 


X 


1 


1 


c 



DF - - 



eh] 



rig. 52 - Example of instruction CO - LONG BRANCH. 



NL8R 


NO LONG BRANCH 


R(P)+2 


C8 


LSKP 


LONG SKIP 





I 1 

] 

1 

When I=C and N=8, the program counter will be 
-incremented twice. For instance, in the instruction 
lequence C85A2B23, the instruction to be executed 
following C8 is 23. The name LONG SXLP, LSKP, may 



also be used (see SKIP instructions). NO LONG 
BRANCH, NLBR, tells the assembler to expect a two- 
byte branch address, while LSKP has no restrictions on 
the next two bytes. 



■ 

3 

J 
I 
J 
1 









ADORESS 


M 


00 


30 


CB 


00 


31 


5A 


00 


32 


23 


00 


33 


23 



•2 



A 1 00 








RIOI 


01 


35 


Rill 


— r 
01 


75 


M2) 


00 


31 


r:3i 







N 


8 


P 


2 


X 


1 


1 


C 



DF- 



LH 



CO 



31 



*2 



ADDRESS 


M 








00 


30 


C8 






RIO) 


01 


35 


00 


31 


5A 






R(ll 


01 


75 


00 


32 


28 






RI2I 


00 


33 


00 


33 


23 






RI3I 







H 


8 


P 


2 


X 


1 




C 



1H - 



DF-- 





Fig. 53 — Example of instruction C8 - 


NO LONG BRANCH or LONG SKIP. 








IF D=0, M(R(P)) -* R(P).1 




LBZ 


LONG BRANCH IF D=0 


M(R(P) + 1) -* R(P).0 


C2 






ELSE R(P)+2 





When I=C and N=2, a conditional long branch is per- 
rormed. If D=0, the contents of the program counter 
R(P) will be replaced with a specified two-byte address, 
if DfO, the program counter is incremented twice. 



.1 



Example: When C2 is fetched from the instruction 
sequence C21A3343, the next instruction to be fetched 
is at memory address 1A33 if DO. If D#), execution 
continues with 43. 



36. 
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AODSESS 


M 




00 


30 


C2 




00 


31 


1A 




00 


32 


33 




co 


33 


43 



j A | UU 


31 






3(0) 


01 35 


ail) 


01 


75 


A|2! 


oo 


31 


R.3I 







N 


2 


P 


2 


X 


1 


1 


C 



EH 



33 



1A 









- 


I- 


31 






N 


2 


















"ST 










P 


2 
















ADD 


RESS 


ID 










X 


1 


00 


30 


C2 






RIO) 


01 


35 






1 


C 












00 


31 


1A 






R(1) 


01 


75 






ALU 




CO 


32 


33 






R(2) 


1A 


33 




DF 






00 


33 


43 






R(3) 








j 


-1 



CONDITION TRUE 



00 31 



ADDRESS 


M 








00 


30 


C2 






Km 


01 


35 


00 


31 


1A 






Rill 


01 


75 


00 


32 


33 






Ri2; 


«, 


31 


oo' 


33 


43 






a, 3i 









N 


2 




? 


2 






X 


1 




1 


C 








ALU 




□ F 








D 


F3 



5 

V 



ADDRESS 


M 


00 


30 


C2 


00 


31 


1A 


00 


32 


33 


CO 


33 


43 



CONDITION FALSE 



A 


OO 


31 




RIO) 


01 


3S 


Rni 


01 


75 


R(2) 


00 


33 


R(31 









N 


2 




P 


2 






X 


t 




1 


C 








ALU 


-! 


DF 











"1 



Fig. 54 - Example of instruction C2 - LONG BRANCH IF D = for both true end 
false conditions. 



LBNZ 


LONG BRANCH IFD NOT 


IFD NOT 0.M(R(P))-*R(P).1 

M(R(P)+1)-» R(P).0 

ELSE R(P)+2 


CA 




LBDF 


LONG BRANCH IF DF=1 


IFDF=1.M(R{P))-*R(P).1 

M(R(P)+1)->- R(P).0 
ELSE R(P)+2 


C3 




LBNF 


LONG BRANCH IF DF=0 


IF DF=0, M(R(P))-> R(P).1 

M(R(P)+1)-> R(P).0 
ELSE R(P)+2 


CB 




LBQ 


LONG BRANCH IF Q=1 


IF Q=1, M(R(P)) "* R(P).1 

M(R(P)+1»->R(P).0 
ELSE R{P)+2 


CI 




LBNQ 


LONG BRANCH IF Q=0 


IF 0=0. M(R(P))-> R{P).1 

M(R(P)+D-*R(P).0 
ELSE R(P)+2 


C9 



II 



Instruction Repertoire 



37 



Skip Instructions 



The SHORT SKIP is unconditional and skips the byte 
following the operation code. The LONG SKIP is also 
nconditional but skips two bytes following the opera- 
on code. The other instructions are long skips if test 



conditions for D, DF, or Q are satisfied. The long-skip, 
instructions require three machine cycles, one fetch and 
two execute, as do the long-branch instructions. 



SKP 


SHORT SKIP 




38 


N8R 


NO SHORT BRANCH 


R(P)+1 



' F When 1=3 and N=8, the byte following the "38" in- 
_;ruction is skipped. The name SHORT SKIP implies 



nothing about the following byte, but the alternative 
name NO SHORT BRANCH implies a branch address. 



LSKP 


LONG SKIP 


R(P)+2 


C8 


NLBR 


NO LONG BRANCH 



When I=C and N=8, the two bytes following the "CS" 
instruction are skipped. The alternative name NO LONG 



BRANCH implies that these two bytes represent an un- 
used branch address. 



LSZ 


LONG SKP !f : D=0 


IF D=0. R(P)+2 


CE 




ELSE CONTINUE 





i: 



! 
1 

1 

]' 

s 

3 



00 



*2 



ADDRESS 


M 








00 


30 


CE 






RIO) 


01 


35 


00 


31 


05 


Rl'l 


01 


75 


00 


32 


72 


R!2i 


00 


3i 


00 


33 


62 


RI3I 









N 


E 




P 


2 






X 


! 




1 


C 








ALU 




DF 








00 



00 



ADDRESS 


M 








00 


30 


CE 






RIO) 


01 


35 


00 


31 


05 






RID 


01 


75 


00 


32 


72 






R(2) 


00 


33 


00 


33 


62 






RI3I 







N 


E 


P 


2 


X 


1 


1 


C 





ALU 





cn 



CONDITION TRUE 



ADDRESS 


M 








oo 


30 


CE 






RiO) 


01 


35 


00 


31 


05 


RID 


01 


75 


00 


32 


72 


Riil 


00 


31 


00 


33 


62 


RI3) 







N 


E 


P 


2 


X 


1 


1 


C 




ALU 





DF 



ADDRESS 


M 


00 


30 


CE 


00 


31 


05 


00 


32 


72 


00 


33 


62 



a 



RIO) 


01 


35 


RID 


01 


75 


R(2) 


00 


31 


RI3) 







N 


E 


P 


2 


X 


1 


1 


C 



F7 



CONDITION FALSE 



Fig. 55 - Example of instruction CE - LONG SKIP IF D =0 for both true and false conditions. 



LSNZ 


LONG SKIP IF D NOT 


IF D NOT 0, R(P)+2 
ELSE CONTINUE 


C6 




LSDF 


LONG SKIP IF DF = 1 


IF DF=1. R(P)+2 
ELSE CONTINUE 


CF 



I 

J 
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1 QMF 
loin r 


i nwfi ^k' ip ip nc -n 

HJINU OMr lr Ur- U 


IF DF=0, R(P)+2 
ELSE CONTINUE 




> 

i 










LSQ 


LONG SKIP IF Q=1 


IF Q=1. R(P)+2 
ELSE CONTINUE 


CD 














LSNQ 


LONG SKIP IF Q=0 


IF Q=0. R(P)+2 
ELSE CONTINUE 


cs 














LSIE 


LONG SKIP IF IE=1 


IF IE=1. R(P)+2 
ELSE CONTINUE 


cc 



When I=C and N=E, 6, F, 7, D, 5, or C, a conditional 
long skip is performed. If the test conditions for D, DF, 
Q, or IE are satisfied, the two bytes following the opera- 
tion code are skipped. If tile test condition is not met, 
normal program execution continues. For instance, if 



instruction "CD" is fetched from the sequence 
CD5525F2, the Q bit is examined and if Q=l , the next 
instruction to be executed is F2. If Q=0, execution con- 
tinues with instruction'"55". 



Control instructions 





IDLE 


WAIT FOR DMA OR INTERRUPT 


00 


IDL 


M(R(0)) -* BUS 





When 1=0 and N=0, the microprocessor repeats exe- 
cute (SI ) c ycles until an I/O request (INTERRUPT, 
DMA-iN, or DMA-OUT') is asserted. When the request is 



acknowledged, the IDLE cycle is terminated and t! 
I/O request is serviced, whereupon norma! operation is 
resumed. 



NOP 


NO OPERATION 


CONTINUE 


C4 



When I=C and N=4, no operation occurs. Execution 
proceeds with the next sequential instruction (A3 in the_ 



I 



H A I 00 I 30 1 



ADD 


RESS 


M 






OC 


30 


4S 






RIO] 


00 


31 


00 


31 


A3 


RID 


00 


72 


00 


32 


32 


RI2] 


00 


30 


00 


33 


F3 


RI3I 







N 


4 


P 


2 


X 


3 


1 


C 



OF - - 



03 



example below). This instruction requires three machine 
cycles, as do the other I=C instructions. 



ADDRESS 


M 


00 


30 


45 


00 


31 


A3 


00 


32 


62 


00 


33 


F3 



-T-GQ33 



RIO) 


00 


31 


RID 


00 


72 


R12) 


00 




RI3I 







N 


4 


P 


2 


X 


3 


1 


C 



DF - - 



Fig. 56 - Example of instruction C4 — NO OPERATION. 



Instruction Repertoire. 
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n 



SEP 


SETP 


N->P 


DN 



When I=D, the digit contained in N replaces the digit 
in P. This operation is used to specify which scratch-pad 
"agister is to be used as the program counter. This in- 
truction causes a jump to the instruction sequence 
beginning at M(R(N)). It facilitates "branch and link" 



r i 

I 



r 1 



f>:o} 






RID 


01 


23 


RI2I 


00 


T7 


ROl 







N 


8 


P 


1 


X 


2 


1 






DF - ■ 



HQ 



functions and subroutine nesting. (These topics are dis-- 
cussed in the section on Instruction Utilization and in 
the section on Programming Techniques under the head- 
ing "Subroutine Techniques".) 



R'.Ol 






RID 


SI 


23 


Rl2l 


00 


37 


Ri3) 








N 


8 


P 


8 


X 


2 


1 






OF ■ • 



HZ 



Fig. 57 - Example of instruction DN - SETP. 



f 1 

I 



SEX 


SETX 


N-X 


EN 



. , When 
| niction 

i 



1=E, the N digit replaces the digit in X. This in- 
is us£d to designate R(X) for ALU and I/O 



byte transfer operations. 



R!0! 






R!D 


01 


23 


R(2I 


00 


37 


RI3) 







N 


3 


P 


1 


X 


2 


1 


E 







ALU 





HZ] 



RIO) 






RID 


01 


23 


RI2I 


00 


37 


RI3I 







N 


3 


P 


1 


X 


3 


1 


E 



DF i 



O 



Fig. 58 - Example of instruction EN - SETX. 



* 1 

I 



SEQ 


SET Q 


1 ->Q 


7B 



i'When 1=7 and N=B, the Q output flip-flop is set. Q 
J-s initially reset to "0" in the RESET mode and can 



later be tested by the branch instructions BQ and BNQ. 



i 
i 



-czmzi 



RIO) 






RID 






RI2I 






RI31 







N 


B 


P 




X 




1 


7 



ALU 







EH 
• CD 



o 



RIO) 






RID 






RI2I 






RI3! 







N 


B 


P 




X 




1 


7 



ALU 







LH 



Fig. 59 — Example of instruction 7B — SET Q. 
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4 



REQ 


RESET Q 


0-Q 


7A 



When 1=7 and N=A, the output flip-flop Q is reset. Q 
is initially reset to "0" in the RESET mode and can later 



be tested by the two branch instructions BQ and BN'i 



RIO! 






RID 






R(2) 






R 31 







N 


A 


P 




X 






7 



ALU 







EE 



R(0t 






RID 






RI2) 






RI3) 







N 


A 


P 




X 




1 


7 



ALU - 



[HZI 



Sy 



■m 

ral : 



Fig. 60 - Example of Instruction 7A — RESET Q. 



Interrupt and Subroutine Handling 



1 1 



The special interrupt servicing instructions can best 
be understood by examining COSMAC's response to an 
interrupt. When an interrupt occurs, it is necessary to 
save the current configuration of the machine by storing 
the values of X and P, and to set X and P to new values 
for the interrupt service program. The interrupt forces 
X and P to be automatically transferred into a tempo- 
rary register T (P goes into the lower 4 bits, while X goes 



into the higher 4 bits), and forces a value of "1" into P 
and "2" into X. In addition, further interrupts are dis- 
abled by resetting the interrupt enable flip-flop (E) to 
"0". Also, a specific code is provided on the COSMAC 
state code line. Details of the interrupt servicing are dis- 
cussed in the section on Interfacing and System Opera- 
tions under the heading "I/O Interface". 



ut 
N 





INTERRUPT ACTION 


X,P->T;1 + P; 2 -* X; - IE 





RIO) 






RID 


CO 


56 


RI2I 


01 


24 


Ri3) 


02 


3C 


It - 1 



N 




P 


3 


X 


4 


1 





* T 43 



RI0I 






RID 


CO 


56 


RI2I 


01 


24 


RI3I 


02 


3C 



IE-0 



N 




t 


1 


X 


2 


1 






ALU 





Fig. 61 - Example of INTERRUPT ACTION. 



SAV 


SAVE 


T-*M(R(X)] 


78 



When 1=7 and N=8, a SAVE operation is performed. 
This operation stores the byte contained in the T register 
at the memory location addressed by R(X). Subsequent 



execution of a RETURN or DISABLE instruction can 
then replace the original X and P values to resume (or 
return to) normal program execution. 



I nstruction Repertoire , 
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MARK 


PUSH X. PTO STACK 


•<X.P)-*T;(X.P)-*M(R(2)) 
THENP-*X;R(2)-1 


79 



V/hen 1=7 and N=9, another save operation is per- 

Irmed. The current contents of the X and P registers 
& stored through the temporary register T and into the_ 



byte in memory addressed by R(2). The contents of P 
are set into X and R(2) is decremented by I. 






71 






HICK 


00 


31 


flil j 


00 


35 


R(2I 


CO 


71 


R(3) 







DF - - 



V 



AOORSSS 


M 


CO 


70 


15 


oo 


71 j 


23 


oo 


72 


48 


00 


73 


□ 1 



A 


00 


71 




R(OI 


00 


31 


Rill 


00 


35 


R(2) 


00 


70 


R(3I 







N 


9 


P 


3 


X 


2 


1 


7 



ALU 



DF . 



Fig. 62 - Example of instruction 79 - PUSH X, P TO STACK. 



1 



RET 


RETURN 


MJR(XJ) (X.P) ;R(X):-: ; 1 IE 


70 







A 


0- 




























•1 


AOORESS 


M 






01 


21 


00 






R'OI 






01 


22 


00 


Hill 


00 


56 


01 


23 


43 


SI 21 


0! 


23 


01 


24 


00 


RI31 


02 


3C 



N 





P 


i 


X 


2 


1 


7 



OF - - 



[I 



1 When 1=7 and N=0, a RETURN operation is per- 
|rmed. The digits in X and P are replaced by the 
memory byte addressed by R(X), and R(X) is incre- 

I 
i 
I 
I 

I 

I 

IWhen 1=7 and N=l, an instruction similar to 
ETURN is executed, except that in this case IE is reset. 
While IE=0, the interrupt line is ignored by the proces- 
sor. 

i 



mented by 1. The 1-bit Interrupt Enable (IE) flip-flop is 
set. 







I ' l 23 l 



ADDRESS 


M 


01 


21 


00 


01 


22 


00 


01 


23 


43 


01 


24 


00 



RIOI 






RID 


00 


58 




01 


24 


RI2I 


R(3I 


02 


3C 



N 





P 


3 


X 


4 


1 


7 



DF - - 



43 



Fig. 63 - Example of instruction 70 - RETURN. 



DIS 


DISABLE 


M(R(X))-> (X.P), R(X)+1;0-* IE 


71 



Either the RETURN or DISABLE instruction can be 
used to set or reset IE, respectively, as explained in the 
section on Programming Techniques under the heading 
"Interrupt Service". 



- 
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Input/Output Byte Transfer 









6N 


OUT 


OUTPUT 


M(R(X)) BUS; R(X)+1 


N=1-7 



When 1=6 arid N=l ,2,3,4,5,6, or 7, the memory byte 
addressed by R(X) is placed on the data bus. The three 
lower-order bits of N are simultaneously sent from the 
CPU to the I/O system. These three N Ones are low at 
all times except when an Input/Output instruction is 
being executed (1=6). The I/O system recognizes these 
conditions and reads the output byte from the lines. 
' The N lines may be decoded with MRD to select or_ 

r-*- N2. N1.N0 (lit) 



control 7 output devices. For more complex system: ;e~ 
"I/O Interface" in the section Interfacing and Sy ;rr, 
Operations. 

R(X) is incremented by 1 so that successively exe- 
cuted output instructions can transfer bytes from jc- 
cessive memory locations. If X is set to the same val^ a r 
P, then the byte immediately following the outpu: 
instruction is read out as immediate data. 



N2.N1. NO 



■ inn 









A 


00 


33 






















ADD 




M ^ 








00 


3. 


12 






RIO) 


03 


36 


00 


32 


24. 






BUI 


00 


J) 


00 


33 


56 






R.» 


00 


33 


00 


34 


78 






RIJ) 







N 


7 


,P 





X 


2 


1 


6 



ADDRESS 


M 


00 


31 


12 


00 


32 


34 


00 


33 


56 


00 


34 


78 



00 



33 



RIOI 


03 


36 


R(l> 


00 


71 


R 121 


00 


34 


not 







N 


7 


r 





X 


2 


i 


6 



HE 



56 



Fig. 64 - Example of instruction 6N (N - 1 - 7) — OUTPUT. 









6N 




INPUT 


BUS -* M(R(X)); BUS -+ D 






N=9-F 



When 1=6 and N=9,A^,C,D,E, or F, an input byte re- 
places the memory byte addressed by R(X). The input 
byte is also placed in the D register. R(X) is not modi- 
fied. The three bits of N are simultaneously sent from 
the CPU to the I/O system during execution of the 

. (—►- N2. N1. NO (0101 



te 



instruction. The I/O circuits should gate an input 
onto the data lines during the execute cycle. The N miss 
may be decoded with M~RT) to select or control 7 input 
devices. For more complex systems, see "I/O Interf 
in the section Interfacing and System Operations. 



■ N2. Nl. NO 1010) 



ADDRESS 


M 










00 


31 


12 






RIOI 


03 


36 


oo 


33 


34 


r:d 


00 


71 


00 


33 


56 


RI2I 


00 


34 


00 


34 


78 


RI3) 







N 


A 


P 





X 


2 




6 



] 



27 







oo 



I 



ADDRESS 


M 








00 


31 


12 






RIO) 


03 


36 


00 


32 


34 






RID 


00 


71 


00 


33 


56 






R(2) 


00 


34 


00 


34 


27 






R(3) 







N 


A 


P 





X 


2 




6 



OF - - 



27 



27 



Fig. 65 - Example of instruction 6N (N = 9 - F) - INPUT. 

DMA Servicing 





DMA-IN ACTION 


BUS-*M(R(0));R(0)+1 








DMA-OUT ACTION 


M(R(0))->BUS;R(0)+1 





During DMA operation, R(0) points to a memory 
location for data transfer. After each byte transfer, R(0) 
is incremented by 1. For concurrent DMA and Interrupt 



requests, DMA-IN has priority, then DMA-OUT, id 
then Interrupt. For further details, refer to "I/O Inter- 
face" in the section Interfacing and System Operations. 



- 4 « 
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instruction Utilization 



In this section, the basic usage of some of the instruc- 
I .ions defined in the preceding section is described from 
1 '.he user's point of view. Additional information on in- 
structions applicable to subroutines and interrupts is 



given in the subsections on "Subroutine 
and "Interrupt Service" in the section on 
Techniques. 



Techniques" 
Programming 



Stack Handling Instructions 



_ These instructions are provided for data movement to 
j from memory, and are well suited for stack han- 
dling. The further use of these instructions in subroutine 

linkages is discussed in the subsection on "Subroutine 
| Techniques" in the section Programming Techniques. 



Example 1. Pushing data onto a stack; saving a register 



Mnemonic Op Code 



I 
I 



GHI R3 
STXD 
GLO R3 
STXD 



, . Load R(3).1 into D 
, . Store it onto stack (push) 
, . Load R(3).0 into D 
. Store it onto stack (push) 



K-2 
K - 1 
K 

K+ 1 



free location 



other data 



t^R(X) 



K- 2 
K - 1 
K 

K+ 1 



free location 



♦fl(X) 



from R(3).0 



from R(3).1 



other data 



- — - — ■ 

IRX 


60 


- LDX 


FO 


LDXA 


72 


STXD 


73 



Stack at start up 



Stack after second STXD 
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Example 2. Retrieving data from a stack; restoring a register 
IRX 
LDXA 
PLO R3 



LDX 
PHI R3 



. . Advance pointer to data 
. . Load data and advance pointer (pop) 
. . Move D to R(3).0 
. . Load data, no advance of pointer (pop) 
. . Move D to R(3).1 



K-2 


free location 


*. R(X) K - 2 








K — 1 


to R(3).0 


K - 1 






K 


to R(3).1 


K 


free location 


■^-R(X) 


K+ 1 


other data 


K + 1 


other data 





Stack at start up Stack after using LDXA and L DX 

Shift instructions 

Mnemonic 



Shift instructions are used for division, multiplica- 
tion, bit and byte manipulation, and testing. A multipli- 
cation by 2 is accomplished by instruction SHL, whereas 
a division by 2 is done by SHR. Bit shifting in either 
direction can be performed either by using the basic 
shift instructions SHR and SHL or by using the SHRC 
and SHLC instructions. For the basic shift instructions, 
zeros are shifted appropriately into the D register; bits 
shifted out of the DF are lost. The shift with carry or 
ring shift instructions retain all bits by shifting them 
through the DF and back into the D register. 



Op Code 



SHR 


F6 • 


SHRC 


76 


SHL 


FE 


SHLC 


7E 



Example. Shifting the contents of die 16-bit register R(5) one bit to the right 



initially 



R(5) 



1A 



75 



0001 1010 
shift 



0111 0101 



SUB1: 



GHI R5 
SHR 
PHI R5 
GLO R5 
SHRC 

PLO R5 
finally 



. . Load #1A into D 

. . Shift it one bit to the right 

. . Store the result (#OD) in R(5).1 

. . Load #75 into D 

. . Shift it one bit to the right 

. . Shifting in carry from SHR 

. . Store the result (#3A) in R(5).0 



R(5) 



0D 



3A 



0000 1101 



0011 



1010 



Instruction Utilization 
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Arithmetic Instructions 



Multiple Precision Addition 

Multiple precision addition is used to add two oper- 
ands of multiple byte length. The multiple precision 
addition is performed by adding the two least significant 
bytes and then adding the next two bytes to the carry 
created by the preceding addition. This operation is re- 
peated for each subsequent byte in an operand. Finally, 
the two most significant bytes are added together with 
the carry from the preceding addition. The DF will be 
set to 1" if there is a carry from the two most signifi- 
cant bytes. 

The ADC instruction together with ADD is used for 
adding two operands of multiple byte length. Consider 
addition of two numbers each 2 bytes long. 

1. The two least significant bytes are added first by 
usins the ADD instruction. The 8-bit sum will be 



Mnemonic Op Code 



ADD 


F4 


ADC 


74 



stored in the D register, and the 1-bit DF (which 
represents the output carry) will be set to "1" if 
there is a carry out from the most significant bit. 
If there is no carry, the DF is reset. 

2. Next, the two most significant bytes are added 
using the ADC instruction. ThVstate "of DF, which 
represents the output carry from step 1 and the 

! input carry to step 2, will be taken into considera- 
tion. The 8-bit sum will be stored in the D register, 
and the 1-bit DF will be set to "1" if there is a 
carry from the most significant bit. 



Example 1. Adding two operands t?913A and ZfSEO — arithmetic 



913A 
+ F3EO 
Sum: 8D1 A, DF = 1 



1001 
1111 



input carry 
{ 
1 

0001 
1011 



0011 
1110 



1010 

0000 



DF=|7j 1000 1101 DF=[j]o001 1010 



output carry 
-S 



Use ADC 



Use ADD 



Example 2. Adding tv/o operands each 2 bytes long - assembly code 



Register MA contains the address of the first operand, while the second 
operand is found in register AC. 



ADDX: 



INC MA 


. . Point to low 8-bit memory location 


SEX MA 


. . Set X to MA 


GLO AC 


. . Fetch AC low 8 bits 


ADD 


. . Add the two low-order bytes 


PLO AC 


. . Store the result in (AC).O 


DEC MA 


. . Point to high 8-bit memory location 


GHI AC 


. . Fetch AC high 8 bits 


ADC 


. . Add the two high-order bits with carry 


PHI AC 


. . Store the result in (AC).1 




. . AC contains 1 6-bit sum 




. . DF = 1 denotes overflow 



46 



User Manual for the RCA CDP1802 COSMAC rVticroproctwsor 



Muitiple Precision Subtraction 

The concept of multiple precision for subtraction is 
analogous to that for addition. It is performed by suc- 
cessive subtractions starting with the two low-order 
bytes and ending with the two high-order bytes. The 
borrow from each step is included in the next higher- 
order subtraction. 

The SDB instruction together with SD is used to sub- 
tract two operands of any byte leng'.h. Consider the sub- 
traction of two numbers each 2 bytes long. 

1. The least significant byte of the subtrahend in D 
is subtracted from the least significant byte of the 
minuend in M(R(X)) by using the SD instruction. 
The 8-bit result will be stored in the D register, 
and the 1-bit DF (which represents the borrow) 
will be set to I if there is no borrow out or to 6 if 
there is a borrow out from the most significant 
bit. 

2. Next, the most significant byte of the subtrahend 
is subtracted from the most significant byte of the 



Mnemonic Op Code 



SD 


F5 


SDB 


75 



minuend using the SDB instruction. The state of 
DF, which represents the output borrow from step 
1 and the input carry to step 2, will be taken into 
consideration. The 8-bit result will be stored in the 
D register and the 1-bit DF will be set to "1" if 
there is a carry from the most significant bit, i.e. 
no borrow. 

Note that upon completion of subtraction: 
DF = means a borrow (the minuend is less than the 
subtrahend). 

DF = 1 means a non-negative result (the minuend is 
greater than or equal to the subtrahend). 

In case of DF = 0, the result is negative; the corre- 
sponding value can be obtained by complementing each 
bit and adding "1" to the result. 



Example 1. Subtracting =?FA92 from £3179 - arithmetic 



input carry 



[ 



M{R(X)): 8179 
- D: FA92 



M(R(X»: 1000 0001 
+ D: 0000 0101 



0111 
0110 



forced by 
hardware 



1 

1001 
1101 



Difference: 86E7, DF = DF =jo| 1000 0110 DF =\o\ 1110 0111 

output borrowT ijse SDB Use SD 

< 1 

(D~ denotes that the D values are complemented) 



DF = 9 



Example 2. Subtracting one 2-byte operand from another 2-byte operand — assembly code 

The operand contained in register AC is subtracted from the operand the 
address of which is in register MA. 



SDX: INC MA . . Point to the low 8 bits 

SEX MA .. Set X to MA 

G LO AC . . Fetch AC low 8 bits 

SD . . Subtract D from M(R{MA)) 

PLO AC . . Store result in (AC).O 

DEC MA .. Point to the high 8 bits 

GHI AC .. Fetch AC high 8 bits 

SDB .. Subtract D from M(R{MA)) with 

. . Borrow 

PHI AC . . Store result in (AC).1 

. . AC contains 16-bit result 
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Interpretation of DF — A Summary 

The four shift instructions and the twelve arithmetic 
instructions are the only ones that can alter the content 
of DF. 

ADD. Executing 74 or 7C allows a carry-in from a 
previous addition, thus facilitating multibyte addition. 
Executing F4 or FC, on the other hand, ignores the 
original content of DF. After any of the four add in- 
structions F4, FC, 74, or 7C, the content of DF will 
indicate if a carry occurred. 

DF = indicates a carry did not occur. 

DF = 1 indicates a carry did occur. In unsigned binary 
representation, DF = 1 also signals an overflow condition. 



SUBTRACT. Subtraction is done in 2's complement 
arithmetic. Each bit of the subtrahend is complemented, 
and the resultant byte plus 1 is added to the minuend. 

Executing 75, 7D, 77, or 7F allows a borrow-in from 
a previous subtraction, thus facilitating multibyte sub- 
traction. Again, execution of F5, FD, F7, or FF ignores 
the initial state of DF. After any of the eight subtract 
instructions above, the content of DF will indicate if a 
borrow occurred. 

DF = 1 indicates no borrow occurred. 

DF = indicates a borrow did occur and that the 
magnitude of the subtrahend was larger than the minu- 
end. The negative answer is then in 2's complement 
representation.. . ... . .. ... 



Branch snd Ski p Instructions 



iKP: When the SKP instruction is used, the byte fol- 
lowing it wi'J be'unconditionally skipped. 

Exampie: SKP .. SKiP the next instruction 

UP:!NCR1 .. INC R1 if a BRANCH to UP 
GLOR1 .. Always do R{1).0->D 

In this case, the INC Rl instruction will be skipped 
and execution continues at the instruction following 
INC Rl, which is GLO Rl. 

The SKP instruction can be used in a subroutine with 
more than one entry point. Depending on the selected 



Mnemonic Op Code 



SKP 
N3R 


38 


LSKP 
NLBR 


C8 



entry, the code for the other entries to the subroutine 
will be skipped. 



Example: 



TYPE5 



TYPE 6 



LDA R5 



LDA R6 



TYPE 



GH! R6 



TY1 




TY1 code 
starts here 


»> 



I 



TYPE5: LDA R5 

TYPE6: LDA R6 

TYPE: GHI R6 
TY1: 



; SKP 
; SKP 



SkiptoTYl 
SkiptoTYl 

Subroutine code starts here 
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In the above example the subroutine TY1 has multi- 
ple entries. When an entry is selected, the other entries 
will be skipped. For example, if TY1 is called via 
TYPES, the LDA R5 will be executed first, and then 
execution continues at the first instruction in TY1 sub- 
routine, skipping over the two entries TYPE6 and TYPE. 

NBR: When the NBR instruction is used, the branch 
to the specified address following the NBR instruction 
will not be taken. 

Example: NBR LABEL 

In this case, a short branch to the address LABEL will 
not occur, and- execution continues at the instruction 
following the skipped byte. This instruction may be con- 
sidered a conditional SHORT BRANCH to LABEL, the 
condition for which is never met. | 

The SKP instruction is a different syntactic form of 
the same machine operation code as for NBR. This form 
does not require an argument. 

LSXP: When an unconditional long skip is executed, 
the two bytes following the instruction will be skipped. 

Example: LSKP; ADD; INC RA 



In this case, the two one-byte instructions ADD; INC 
RA will be skipped, and execution continues at the in- 
struction following INC RA. 

The conditional long skip is used to skip on specific 
conditions of the two bytes following the instruction. 

Example: LSDF . . If DF = 1, RSHR 
ANI#01 ..Else AND #01 
MA: RSHR . . Always ring shift 

In this example, the two-byte instruction ANI #01 will 
be skipped if DF = 1 and execution continues at label 
MA. 

NLBR: When the NLBR instruction is used, the long 
branch to the specified two-byte address following the 
instruction will not be taken. 

Example: NLBR LABEL 

This instruction may be considered a conditional long 
branch to LABEL, the condition for which is never met. 

The NLBR and LSKP, and NBR and SKP pairs, have 
the same machine 'operation code. The two assembler 
syntaxes for each pair exist for the convenience of the 
user and to aid program debugging. 



Control Instructions 



NOP: The NOP instruction causes only the program 
counter to be incremented; it has no additional effects. 
This instruction is useful in timing loops to provide a 
time delay or wait function until, perhaps, a certain 
operation has been completed. 

Example: 



MA: 



Mnemonic 



Op Code 



SDI 50 


. . Load number of loops 


PLO R6 


. . into R6 


DEC 


. . Reduce count 


NOP 


. . Delay one instruction 


GLO R6 


. . Test for done 


BNZ MA 


. . If not done, branch 




. . Time expired; continue. 



The NOP instruction can also be used to reserve space 
for other code which may be unknown at the time the 
program is prepared. Additionally, it can be used to re- 
place an instruction in a program, thus removing its 
effect, a useful debugging technique. 

SEP: The SEP instruction is used to specify which 
scratch-pad register is to be used as the program counter. 
This instruction causes an immediate jump to the in- 
struction sequence beginning at M(R(N)) and R(N) be- 
comes the program counter. The instruction facilitates 
branch and link functions and subroutine nesting (refer 
to subsection on "Subroutine Techniques" in the section 
Programming Techniques). 

SEX: This instruction is used to designate R(X) used 
by some logic, arithmetic, register, or I/O byte transfer 
operations. Setting X to a new value assigns a register 



NOP 


C4 


SEP 


DN 


SEX 


EN 


SEQ 


7B 


REQ 


7A 


SAV 


78 


MARK 


79 


RET 


70 


DIS 


71 



R(X) to be used as a pointer to the data byte. 

Example: Designating an R(X) can be used to advantage 
when two bytes stored at different memory locations are 
compared. The first byte is stored at M(R(7)), and the 
second is stored at M(R(8)). 

COMPAR: SEX R7 . . R(X) points to byte one 
LDX . . Load the first byte into D 

SEX R8 . . R(X) points to byte two 
SM . . Compare the two bytes 

. BNZ XYZ . . Branch to XYZ if no match 
. . Else continue here 

WHEN X = P: There are three instructions which 
have particular usefulness when X is set equal to P: the 
OUTPUT instructions (61-67), the RETURN instruction 
(70), and the DISABLE instruction (71). Because each 
of these instructions increments the R(X) register, when 
X = P the R(P)/R(X) register will be incremented once 
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for the fetch cycle when it acts as a program counter and 
once foi the execute cycle when it acts as R(X). As a 
result, the byte immediately following the instruction 
byte is the operand byte. For example, if P = 3, the 
sequence will output the byte AD by means of the data 
bus. 

E3 SEX R3 ..SetX = 3 
61 OUT 1 . . Output a byte from memory 

AD #AD .. Immediate byte 

— . . Next instruction 

Tin's technique is also useful with the RETURN and 
DISABLE instructions, as discussed in the subsection on 
"Interrupt Service" in the section Programming Tech- 
liques. 

SEQ and REQ: Q is a flip flop brought out of the 
CDP1S02 as a single output line. Q can be set (SEQ) or 
reset (REQ) under program controi and later tested in 
the program by the conditional branch instructions BQ 
and BNQ. Depending upon the outcome of the test, the 
program can decide upon a course of action. Note that 
at start up, th e Q line is rese t (Q = C) by the RESET 
mode (CLEAR = L and WAIT = H). 

For example, the SEQ and REQ instructions can be 
used to send serial bits of data to an output device (TTY 
for example). The length of each bit is determined by a 
time delay subroutine. See Fig 66. 

Another application is the control of an external 
relay or lamp. 

SAV: When an interrupt occurs, X and Pare auto- 
matically transferred into the temporary register T. The 



SAV instruction is used in the interrupt subroutine to 
store the byte contained in the T register onto the stack. 
It is usually preceded by a DEC R2 instruction to make 
sure that R(2) is pointing to a free memory location. 
Subsequent execution of a RETURN or DISABLE 
instruction can replace the original X and P values to 
return to the interrupted program for normal execution 
(refer to subsection "Interrupt Service" in the section 
Programming Techniques). 

MARK: A primary use of the MARK instruction is 
to facilitate nested subroutine linkage when multiple 
program counters are employed. This use is exemplified 
in the subsection on "Subroutine Techniques" in the 
section Programming Techniques). 

A secondary use of the MARK instruction is simply 
to determine X and P by storing their values in memory 
for subsequent analysis. This capability is useful in the 
design of debugging aids. 

RET and DIS: Because the interrupt mechanism 
stores X and P in the temporary register T and is typi- 
cally followed by the execution of SAV instruction, 
M(R(2)) contains the value of X and P at the time of 
interrupt. The DIS and RET instructions are used to 
restore the machine status (X J 3 ) from M(R(2)) and give 
control back to R(P). The DIS instruction also resets the 
interrupt enable flip-flop (IE=0), while RET sets the 
interrupt enable flip-flop (IE~1). Thus, a return from an 
interrupt program or subroutine may be made with 
either interrupt processing enabled or disabled. 

The two instructions RET and DIS can also be used 
in nested subroutine calls in conjunction with the 
MARK instruction (See subsection "Subroutine Tech- 
niques" in the section Programming Techniques). 



COSMAC 



CPU 



r SEQ 
f ■, 


p RE 

7 















TTY 



INTERFACE 



Fig. 66 — Sending serial data from microprocessor fo TTY interface. 
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Programming _i_echniqu®s 



The purpose of this section is to discuss basic pro- 
gramming concepts especially c.s they relate to the writ- 
ing of COSMAC programs. It is intended for engineers 
new to programming. Experienced programmers, how- 
ever, are also encouraged to read this section to get a 
feeling for the differences between COSMAC and more 
conventional computer architectures. 

Resource Allocation. 

Before detailed programming can begin, decisions 
must be made as to which functions are to be executed 
by software and which are to be implemented in the 
input/output hardware. The layout of data in memory 
must be planned and the utilization of registers worked 
out. 

The hardware/software tradeoff is often the most 
difficult but rewarding phase of designing a micro- 
processor-based product. On the basis of previous famili- 
arity, engineers may tend to favor incorporation of hard- 
ware timers, decoders, rate multipliers, etc. when these 
functions might be done more economically in software. 
Generally, the system designer should attempt initially 
to do everything in software (except jobs requiring sub- 
microsecond response), pushing functions out to special 
I/O hardware only when the CPU cannot keep up. He 
may find, even then, that a second CPU/ROM subsystem 
is more cost-effective than special-purpose hardware. 

Allocation of the various built-in I/O capabilities of 
COSMAC is difficult to discuss in genera! terms because 
applications are so varied. The DMA channel can clearly 
be used for CRT refresh from memory and for block 
transfers such as between a floppy disc and memory. 
The decision whether to use the DMA or the Interrupt 



channels for a slow communication line is more difficult 
and depends on what other I/O interfacing is required. 
More subtle uses of DMA include simply using R(0) as a 
counter (ignoring the data transfer), and using DMA to 
cycle through a sequence of A/D conversions, for 
example. The input flags are obviously appropriate for 
slow-varying binary real-world inputs, but can also be 
used by I/O circuits to signal status to the CPU. The Q 
level output may be used as the system output, to signal 
I/O circuits, or even to select banks of memory. 

Often, the most basic system design issue is deciding 
what functions to carry out in response to one or more 
interrupt signals. Generally, the less done in servicing 
interrupts, the better. In this way the amount of book- 
keeping overhead is minimized each time an interrupt 
comes in. It also minimizes the problems of contention 
among multiple interrupt signals. Furthermore, it makes 
the system easier to design, debug, and more likely to be 
error-free. 

f*AM_and Register Allocation _f or Data 

Registers must be allocated among program counter 
usage, data pointing, storage usage, and genera! utility 
usage. This allocation many vary dynamically as a pro- 
gram executes, but generally it is more efficient to assign 
fixed functions to most registers. The utility registers 
may be used differently by different parts of the pro- 
gram. Allocation as program counters will be discussed 
later. 

Data may be considered as: I) isolated variables, 
parameters, or switches which are referred to at many 
different parts of a program, 2) temporary, intermediate 
results obtained in the process of a computation and then 



52 



Usar Manual for tha RCA CDP1C02 COSMAC Microprocessor 



Ihrown away, 3) constants used as masks or for compari- 
sons, for example, and 4) strings, blocks, or tables of 
data which relate possibly to I/O operations or are stored 
in ROM. These types of data are respectively best han- 
dled 1) by direct use of registers to hold the random iso- 
lated va.-bh'es, 2) by use of a memory "stack" (defined 
below) for intermediate results, 3) by use of data inter- 
mediate instructions for constants, and 4) by use of 
register pointers into memory for strings, tables, etc. 

The advantage of using register storage directly is that 
simple 1-byte instructions are used to bring data to and 
' from the D register, saving time and program space com- 
pared with storing them in RAM. Furthermore, a param- 
eter which needs to be incremented or decremented can 
be stored in the low half of a register and incremented or 
decremented in place without using the D register. 

A stack is a last-in first-out storage mechanism. It is 
best implemented in COSfviAC by dedicating a block of 
RAM and using one register R(2) to point at the "top" 
of the stack, i.e., the space where the next byte should 
be put. The programmer "pushes" intermediate results 
onto the stack for storing using R(2) as the pointer and 
then decrementing the pointer (so that the block of 
RAM used starts at the highest address). Later, he 
"pops" them off when he is ready to use them by a load 
or ALU instruction, incrementing the pointer before he 
docs so. Users of certain Hewlett Packard calculators will 
be familiar with the idea that a stack can be used to 
organize a very complicated calculation. 

(A Programming Note: Often, a programmer knows 
he will be using a piece of data pushed onto the stack 
soon with no intervening further use of the stack. In 
such cases he will omit the decrement of the pointer 
after pushing data and the increment before using data, 
thus saving one or two instructions. Such deviations 
from standard usage should be well marked by com- 
ments in the program to avoid problems in case the code 
is changed later.) 

There are many good reasons to use a stack mechan- 
ism, some of which are discussed subsequently in the 
material on program structure and subroutines. For now, 
the main reason is efficiency of resource use. First, only 
one register pointer R(2) is required to work with a 
potentially large number of pieces of data. Second, RAM 
is used efficiently because the allocation of space re- 
quired must match the maximum number of interme- 
diate bytes stored at any given time, rather than the 
total required over the duration of the program (The 
maximum "depth" of a stack is generally very small). 
Third, the stack is efficiently addressed by 1-byte 
COSMAC Instructions, thus saving program space. 

The data immediate mo-de of addressing is the best 
COSMAC practice when constants 3re needed in a pro- 
gram. This mode provides best economy of resources in 
most cases (no need for a special pointer to memory), 
2nd a I -byte load or ALU instruction suffices to address 
it. Furthermore, this mode makes code easiest to "read" 
because each constant used is found at the point in the 



program where it is needed and its value is immediately 
obvious. Constants can readily be located and changed 
during the programming process. With this approach, a 
constant which is used at several different places in a 
program will be stored several times. In extreme cases it 
may be better to set up a pointer to such a'constant. In 
most cases, however, the data immediate mode is usually 
best. 

Data which appears as a string of bytes is best stored 
in RAM and addressed by setting up a register pointer to 
it. Multiple strings usually should have multiple address 
pointers. The COSMAC instructions are designed to 
work efficiently with such data, allowing the pointer to 
be incremented and decremented as the bytes of data are 
accessed. Sometimes, the programmer will share a few 
pointers . between several different strings of data not 
being simultaneously accessed. In this case, it is good 
practice to allocate all strings to one 256-bytc page of 
memory so that a pointer can be moved from one data 
item to another simply by loading the lower byte of the 
pointer register. 

ROM tables, when frequently used, may also justify 
a dedicated pointer. 

Writing a Program 

Structure is the essence of programming. The better a 
programmer Ci ganiz.es the program's structure, the 
quicker tjie design, the more efficient the result, and the 
more likely it is to be correct or "bug-free." 

Loops 

The most characteristic structure in programming is a 
simple loop. A loop consists of an initialization section, 
a main body of steps to be executed, and a test section 
to determine whether and how often to "loop" through 
the main body. As a simple example, consider a routine 
which implements a delay. Fig. 67 shows such a routine 
in three forms: flow chart, symbolic, and numeric. The 
programmer should become familiar with all three of 
these representations. 

The flow chart (Fig. 67a) shows the program struc- 
ture explicitly and says in words what happens at each 
point in the structure. 

The symbolic form, shown in Fig. 67b, specifics the 
instructions to be executed and includes the movement 
of data among the various COSMAC registers. The delay 
constant, wlu'ch is assumed to be stored in a memory 
location, is loaded into D and then moved to the lower 
half of a utility register UTIL. The expression "LOOP:" 
labels the next part of the program for future use. Three 
"NOP" instructions are specified. These instructions are 
the main body of the loop. Then, the utility register is 
decremented. Finally, the lower half of UTIL is loaded 
into the D register and a conventional branch instruction 
is executed. Control keeps going back to the "LOOP" 
until the count goes to zero. 
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LOAD DELAY 
CONSTANT 



LDX 



LOOP: NOP 



EXECUTE SOME 

NO ore to 

KILL TIME 



NOP 



NOP 



DECREMENT DELAY 
CONSTANT 
DONE YET? 



J NO | YES 
a. l-"low chart form 



b. Symbolic form 



. . Load delay constant 


0103 F0 


. . into UTIL.O 


0104 AS 


. . Kill time 


0105 C4 


. . Kill time 


0106 C4 


. . Kill time 


0107 C4 


. . Decrement 


0108 28 


. . Branch if not 


0109 88 


. . Eke continue 


010A3AOS 


l 


c. Numeric form 



Fig. 67 — Simple loop example: delay function. 



This same prog/am is also shown in Fig. 67c in 
numeric form, which is as it might appear in hexadeci- 
mal code. Note that UTILis assumed to be R(8). 



Conditional Branches 

A second characteristic structure in programs em- 
ploys the conditional branch. In the conditional branch, 
a comparison or test of some kind is made, and one of 
two different bodies of code is executed, depending on 
the outcome. Fig. 68 illustrates a simple example where 
the intention is to fix a lower bound to a variabie Z and 
substitute a constant 03 if Z is less than 03. Note that 
once the appropriate action is carried out, the two 
branches of the program come back together. 

By defining steps in a loop to be themselves loops or 
conditional executions, and by building up a hierarchy 
of nested loops and conditionals, any function can be 
programmed. Structures of this type are the most effi- 
cient to generate, the most efficient to check out, and 
the least likely to contain undetected bugs. More compli- 
cated structures are very common (they appear in RCA 
utility programs, for example), because programmers 
like to play "tricks" such as branching from one part of 
a program into another, sharing a common part for a 
while, and then branching back to the original part con- 
ditionally on some obscure characteristic that distin- 
guishes the two program parts. These practices, however, 
lead to problems. A simple change in the one part of 



code may have unfortunate consequences for another 
part which is "borrowing" a piece of it in the above 
manner. The optimum flow chart is usually one without 
odd-looking branches from one part to another. 

Subroutines 

Very often, however, a piece of program is useful in 
many different place in the total program— a multiply 
routine, for example. To avoid the dangerous practices 
referred to above, but still to need have only one copy 
of such a routine present in memory, the programmer 
should use the concept of a subroutine. A subroutine is 
a generalized form of instruction, a subprogram wliich 
does something that might have been implemented in 
the original CPU as an instruction. It should be exactly 
defined so far as the function it performs, where it gets 
its data and puts its results, and what resources it uses- 
registers and RAM. Subroutines may have the structure 
of a loop or of a conditional branch, and in cither casa 
may themselves use other subroutines within the body 
of their code. The main design effort in a large program 
is in the building up of a set of subroutines suitable for a 
given application. 

COSMAC offers many different ways to handle sub- 
routine structure, representing different tradeoffs among 
efficiency in execution time, efficiency in program size, 
and efficiency in use of register resources. These ways 
are described in the next part of this section. COSMAC 
also offers more direct mechanisms for treating subrou- 



COMPARE 2. 3 



Z>03 



. .Assume R(X) points to Z 
L0X ..Fetch Z 0213 FO 



Z<03 



SET Z-03 



SMI 03 
BGE EXIT 
LDI 03 
STXD 



. Compa/e with 03 

. Load 03' 

. end store at Z 



EXIT: 



a Flow chart form. 



b. Symbolic form. 



0214 FF 03 
021633 18 
0213 F8 03 
021A 73 

0218 

c. Numeric form. 



Fig. 63 — Simple conditional branch example: limiting a variable. 
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tines as extensions of the basic instruction set. These 
interpretive techniques are described in the last part of 
this section on Programming Techniques. 

Subroutine Techniques 

In large programs, a particular sequence of instruc- 
tions is often used many times. For example, a code 
conversion from one data format to another might be 
required several places in a communications program. A 
straightforward approach to programming the code con- 
version is to insert the proper sequence of instructions 
each p ; ice in the program where the needed function is 
to be performed. This duplication of instructions, how- 
ever, would consume much memory storage space, espe- 
'ally if the sequence is long. An alternative method is to 
,/ritc the sequence only once and reuse it eacli time it is 
needed. This shared usage of the same code is accom- ' 
plished by writing the function as a subroutine which 
can be called each time it is needed. When the subrou- 
tine has completed its function, it returns to the pro- 
grain that called it. A subroutine may be called many 
times from different places in the main program. Most 
programs will contain several subroutines. 

!f subroutines are required frequently, the most 
efficient technique for entering and exiting from the 
subroutine should be used. The COSMAC architecture 
provides several techniques for calling and returning 
from subroutines. The particular technique or combina- 
tion of techniques to be used is determined by the com- 
plexity and requirements of the function to be per- 
formed. In the following material, each of three tech- 
niques is described along with application examples. 
Although the techniques are described independently, 
they are not mutually exclusive and features of each can 
'~e combined. 

SEP Register Technique 

The SEP register technique is the fastest and yet the 
most basic subroutine cail and return convention. It util- 
izes the COS?>!AC architecture to rapidly change pro- 
gram counter assignments from one register to another. 
The procedure is as follows: 

STEP 1. Point one of the 16 registers to the sub- 
routine that the program will cail. This step is typically 
accomplished by executing the following code: 
LDI A.O{sub) . .replace "sub" with subroutine name 
PLO Rn . .replace "n" with a register number 

LDI A.1 (sub) . ."sub" is the entry point to the subroutine 
PHI Rn . ."n" is the register to point to "sub" 



This four-instruction sequence will load the address 
of the first instruction in the subroutine into a register. 
Thus, the register "n" will point to the entry point of 
the subroutine. If the programmer does not use tliis 
register for any other purpose than to point to the sub- 
routine, the initialization procedure need be done only 
once. If, however, the same register is to be used various- 
ly in the program to point to another subroutine or to 
hold data, then, before additional calls, the legister must 
be reinitialized. 

(Note: In many of the examples to follow it will be 
necessary to initialize pointers using the four-instruction 
sequence given above. As a shorthand notation, this 
instruction sequence will be represented by a statement 
such as: 

LOAD 'RN', 'SUB'. 

This statement happens to conform to that required of 
an assembler macro call, but for present purposes its use 
is intended for saving space.) 

STEP 2. A call to the subroutine is performed by 
making R(n) the program counter. This change is done 
by executing the instruction SEP to register "n". Execu- 
tion of the subroutine will then begin with R(n) as the 
program counter. Because the initial value of P is at 
program start up, this technique is also used to change 
program counters from R(0) to any other register as 
shown in Example 1 below. 

STEP 3. A return from the subroutine is performed 
by making R(p) the program counter where p was the 
register used as the program counter by the calling pro- 
gram at the time of the call to the subroutine. This 
change is done by executing the instruction SEP to regis- 
ter "p". The execution of the calling program will re- 
resume with R(p) the program counter. Examples 2 and 
3 illustrate this SEP Register Technique. 

The procedure above in basic and expanded forms is 
illustrated in the following three examples. 

Example !. Change the Program Counter from R(0) to 
R(N). 

Any COSMAC program always starts with R(0) as the 
program counter. Changing from R(0) to any arbitrary 
register (R(3) in this example) may be necessary to free 
R(0) for later use as a DMA pointer. 

The address of the first instruction in the main pro- 
gram is loaded into R(3). Then, a SEP R3 instruction 
will cause the main program to use R(3) as the program 
counter thereby freeing R(0) for DMA use. The register 
assignment table is given in Fig. 69. 



Register 


Function 


Comment 


mm 


Initial program counter 


Defined by hardware 




Later, DMA pointer 




R(3) 


Program counter 


Register # is arbitrary 



Fig. 69 - Register assignment table for Example 1. 
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Programming Technique: 

Execution begins at location 0000 with R(0) as the program counter. 
Load the address of "MAIN" program into R(3): 



LOAD 'R3\ 'MAIN' . . Lo»d A{MAIN) into R(3) 



■ PC ■ RIO) 



Change program counter to R(3) to effect an immediate call to the main program: 



SEP R3 



. . Execution starts at label "MAIN' 



MAIN: 




. . "MAIN" program code starts here 

. . More code in the "MAIN" program 
i 




END 


. . End of JOorce progrjm 




A typical assembly listing for Example 1 is given in Fig. 70. 



Program counter 


M Address 


M Byte 


Assembly program 


Comment 


R{0) 


0000 


F834 


LDI A.l (MAIN) 


. . Point R3 to 






0002 


A3 


PLO R3 


. . "MAIN" program 






0003 


F812 


LDI A.1 (MAIN) 








0005 


B3 


PHI R3 








0005 


D3 


SEP R3 


. . Change PC to R3 














R(3) 


1234 




MAIN: ORG * 


. . "MAIN" program 












starts here 


< 


F 














Fig. 70 - 


Assembly listing for Example 1. 



Example 2. Main Program Calling a Subroutine. 

In this example, a subroutine is called by loading its 
address into a register and using "SEP register" to do the 
call. The subroutine is called from two places in the 
main program. When it has performed its function, the 
subroutine does a return by doing a SEP back to the 



register of the main program. This returning SEP instruc- 
tion is performed just in front of the entry point to the 
subroutine. This step leaves the subroutine's program 
counter as it was originally (i.e., pointing to the same 
■ location as at initialization). Thus, the initialization need 
be done only once in this example. The register assign- 
ment table is given in Fig. 71 . 



Register 


Function 




Comment 


R(3) 


The "MAIN" 


program pointer 


Arbitrary 


R(7) 


"Subroutine" 


entry pointer 


Arbitrary 



Fig. 71 — Register assignment table for Example 2. 
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Programming Technique- 
Execution starts with R(0) as the program counter. 
Load the address of "MAIN" program into R(3): 



LOAD R3'. MAIN' . . Load A(MAIN) into RI3) 



■ PC - RIO) 



Load the address of subroutine "SUB1" into R(7): 



LOAD R7\ -SUSV . . Load A1SU31) inlo R(7) 



- PC ■ RIO) 



Change program counter to R(3) to give control to "MAIN" program: 



I 

I 



To "MAIN" 



SEP R3 



, . Execution reiuinet at label "MAIN" 



- PC bKorwi R(3) 



. . GENERAL PURPOSE AREA 
. . Place data or subroutines here 



To SUB!" 



From "SU91 



To "SUB 1" 



From 'SUB 1 



MAIN: 



. "MAIN" program execution starts here 
. More code in "MAIN" program 



SEP R7 



.Call "SUB1" 



. "SUB 1 " returns here 
. "MAIN" program code 



SEP R7 



.Can call "SUB 1" again 



BR MAIN 



. . '"SUB 1" returns here 
. . "MAIN" program code 

. . Start "MAIN" again 



PC • R(3) 



PC becomes R(7) 



Flrturn 



From CALL 
I 



EX1T1 : 


SEP R3 




. . Return lo the mvfnltn* code 


SUB1: 




. . "SUB 1*" ex scut ion rtiKtJ her* 






, . More code in "SUB 1 " 




BR EXIT. 


. . Branch to entry point 






. . of "SUB 1" minus one byte 






. . Thij leavei R(7) pointiarg 






. . to "SUBfellowing following 






. . repeated c»lls 



PC restored as R(3( 
•PC - R(7I 



END 



. . End of program source 
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Example 3. Main Program Calling Two Subroutines. 

This is an example of a source program containing 
two subroutines (SUB1 and SUB2). These two subrou- 
tines are called from several places in the mainline. A 
separate register is assigned to each subroutine entry 
point permitting rapid subroutine calls and requiring no 
reinitialization of pointers before successive calls. The 
register assignment table is given in Fig. 72. 



Register 


Function 


Comment 


R(3) 


"MAIN" program counter 


Arbitrary 


R(7) 


"SUB1" pointer 


Arbitrary 


mm 


"SUB2" pointer 


Arbitrary 



Fig. 72 — Register assignment table for Example 3. 
Programming Technique: 
. . Execution starts with R(0) as the program counter. 
. . Load the address of "MAIN" program into R.(3): 





LOAD 'R3\ 'MAIN' 


. . Load A(MAIN) into R(3) 




-PC - R(0) 


.Load the address of subroutine 


'SUB1" into R(7): 










LOAD R7-. -SU3I- 


1 

..Load A(SU81) intoR(7) 




-PC - RIO) 


. Load the address of subroutine 1 


"SUB2" into R(8): 










LOAD R3-. -SUB2 - 


. . Load A(SU32) into R(3) 




-PC - RIO) 


.Change program counter to R(3) to give control to 


''MAIN" program: 







To "MAIN 



SEP R3 



. . Execution reiun-.M at label "MAIN" 



PC becor.M RI3) 



. . GENERAL PURPOSE AREA 
. . Place data or subroutines here 



To "SUB!" 



From 
"SU31' 

n 



To "SU82- 



From 
"SUB 2" 

n 



To "SUB!" 



From 

••suai- 

n 



MAIN: 



SEP R7 



SEP R8 



SEP R7 



BR MAIN 



. "MAIN" program execution starts here 
. Mere code in "WAIN" program 



..Call "SUB!" 



. . "SUB I" returns here 

.-. More code In "MAIN" program 



..CjJI~SU92" 



. . "SUB2" returns her* 

. . More code in "MAIN" program 



. Can call "SUB 1 " again 



. "SUB! " return* here 

. More code in "MAIN" program 

. Program 

. Sua "MAIN" e«ain 



PC-RI3) 



PC becomes R[7) 



PC becom«s R(3) 



PC becomes R(7) 
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EXIT 1 : SEP R3 
SU31: 



BR EXIT1 



EXIT2: SEFR3 
SU32: 



ER EXIT2 



END 



. . Return to the mainh'n* call 



. . "SUB I" execution ttaru here 
..More code in "SUB 1" 

. . Branch up to before entry 
. . lo restore R(7I 



. . Return to the mainline call 



. "SUS2" execution starts here 
. More code in "SUB2" 
. Branch up to before entry 
. to restore R(8J 



. End of program sourca 



•PC reitored at R(3! 
PC-R17) 



PC rMtcxed at RI3) 
PC - R(8) 



Fig. 73 is a pictorirJ representation cf Exr.rnple 3. 
The "MAIN'" r.;ogran! is running in R(3) 
;i SUBl " tmi in I'll) 
: -SUB2" runs in ?.(8) 
Tocdl "S\JBV\ 5EP R7 
Tocsll "5U£3".S&SS 
To rttura to &s "MA&F program, fJE? R3 

Note that the subroutines "SlEl" and "SUB2** are 
mu.udiy exczusj-.-e in ;h?t u SUtH w cannot csS "SU22", 
or vfcs versa, because "SUS2" always returns to ihe 
caUer with a SEP ft!. In order for "SUB2" to return lo 
"SUB! ", if would have to do a SEP R7. Caution must be 
exercised to assure that a subroutine "knows" the cur- 
rent program counter for the return. 

MARK Subroutine Teshrrqua 



In each of the preceding examples, every subroutine 
had to know The program counter cf the calling program 
In order to do the proper SEP for the return. In large 
complicated programs where subroutines call other sub- 
routines, a given subroutine may have to return to differ- 
ent program counters at different times. This problem 
may be overcome with the use of the "MARK Subrou- 
tine Technique," a technique which is required only 
when subroutines are nested (call one another), and the 
order of nesting varies dynamically. 

The MARK instruction is used to save the current 
value of X and P in an area of memory called a stack. In 
a COSMAC based system, this stack consists of any num- 
ber of locations in RAM pointed to by a 16-bit user- 
specified register. The pointer contains an address which 
enables the CPU to find the current "top" of the stack. 
The stack provides for temporary storage and retrieval of 
successive bytes of information in a last -in first-out man- 



MAIN PROGRAM 
PC - R(3) 



- SEP R3- 
-SEP R7- 



SU31 
PC-fi(7) 



-SEP R3- 
-SEP R3- 



SU82 
PC - R(8) 



Fig. 73 — Pictoiial representation of prog am courier 
e-ssig-iments. 



ner. When a byte of information is stored in the stack, it 
is stored at the address which is specified by the con- 
tents of the stack pointer. The stack pointer is then 
decremented by one, enabling another byte to be 
"pushed" onto the stack "on top" of the last one stored. 
Hence, the stack pointer points to a free memory loca- 
tion. Conversely, to retrieve information from the stack, 
the pointer is incremented by one and the byte is 
"pepped' from the stack by loading it into a register. 
The top of the stack is then free for other "push" opera- 
tions. The programmer must make sure that the stack 
pointer is initialized to an appropriate high address 
memory location before an instruction that uses the 
stack is executed. 

In the COSMAC architecture, R(2) is the most 
natural register to use as a stack pointer because of the 
way interrupts are handled (X is set to 2). 

The use of the MARK instructions also provides 
another benefit. The calling program may pass data 
(parameters) to the subroutine via "inline" data lists. 
An inline data list is a block of immediate constant data 
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supplied by the calling program to the subroutine. Thl3 
data is adjacent to (Inline with) the call statement. In 
Example 4, SUB1 passes an Inline #24 to SUB2. 

The MARK Subroutine Technique works as follows: 

1. The calling program executes a MARK Instruction. 
This instruction pushes the values of X and P onto 
the stack pointed to by R(2) and then copies P 
Into X. The current value of X is now the same as 
the old value of ?. P remains the same. 

2. The calling program calls the subroutine via a SEP 
instruction to a register that points to the sub- 
routine. The execution of the subroutine then 

- begins. - - - . 

3. If the calling program has provided inline parame- 
ters to the subroutine, then the subroutine picks 
up these parameters by executing LDXA Instruc- 
tions. This procedure will lead the next parameter 
to the D register and automatically advance the 
caller's program counter (R(X)) to the next byte. 
There should be es many LDXA instructions as 
there are inline data bytes. Thus, the passing of 
data is accomplished without the subroutine 
knowing the old program counter (X designator). 

4. After the subroutine performs its task, it returns 
to the caller by setting X to 2, incrementing R(2) 
(preparing R(X) for a return), and executing a 



RET Instruction. These instructions will load the 
contents of memory byte pointed to by R(2) to 
the X and P registers. Processing continues with 
the calling program running with its original X'and 
- P. 

5. Upon return of control from the subroutine to the 
calling program, the calling program must decre- 
ment R(2) to compensate for the increment in the 
RET instruction. 

Example 4. Main Program Calling Nested Subroutines. 

This example illustrates a program that has two sub- 
routines, Both subroutines are called by the main pro- 
gram. One of the subroutines is also called by the other 
subroutine. The register assignment table is given in 
Fig. 74. 



Renislsr 


Function 


Comment 


R{2) 


Stack pointer 




R{3) 


"MAIN" program countsr 


Arbitrary 


R{7) 


"SUBV pointer 


Arbitrary 


nm 


"SUB2" pointer 


Arbitrary 



Fig. 74 — Register assignment table for Example 4. 
Programming Technique: 



, . Execution starts at location 0000 with R(0) as the program counter. 
. Load the address of "MAIN" program into R(3): 



LOAO 'R3'. 'MAIN' . . t-Md A(MAIN) Imo R(3) 



-PC -RIO) 



Load the address of subroutine "SUB1" into R(7): 



LOAD 'R7', 'SU31' . . Lo*d AI5US1) Into R(7) 



-PC -RIO) 



..Load the address of subroutine "SUB2" into R(S)^ 



LOAD 'R37SUar . . Led A(SUS2) Imo R(3) 



-PC -RIO) 



Set stack pointer R(2) to a RAM area: 



LOAD 'R2-.-STACK' . . Lo*J AISTACK) into R(2) 



-PC - RIO) 



To "MAIN' 



SEP R3 



. . Extcution resufT}*i at lib«l "MAIN" 



■ PC btcomti RI3) 



. GENERAL PURPOSE AREA 
. Pt*:e dit« Of tojbroutinw h*ra 



/ 
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To "SU81- 



From 
"SUBf 



MAIN: 



To "SU32" 



MARK 



SEP R7 



DEC R2 



BR MAIN 



EXiTi: RET 
SU81: 



MARK 



SEP R8 
.#24 



DEC R2 



SEX R2 

INC R2 
BR EXITJ 



. "MAIN" program execution rlerti hare 
. Mofe tod* In "MAIN" program 
. Save the stats of the machine 
. (X/) - (2,3) onto nack 
. Note that X - P - 3 now. 



.. CUli "SUBI" 



. . Fix ittck, pointtr 
. . "MAIN" program continue* 
. . Mors code in "MAIN" prog.- 
. . Start "MAIN" again 



. Return to "MAIN" program 

. "SU21" execution itarli here 

.Code in "SUBI" 

. More code in "SUB 1 " 

.Prepare to cell "SUB2" 

. Sive (X.PJ - (3.7) onto Hack 

. Note that X - P - 7 now. 



.Cell "SUB2" 

. Pali a data byts to "SU32" 



. Fix tt-ck pointer on return 

. from "SUB2- 

. More code in "SUBI" 

. Point R(X| to Hack for return 

. Point to old IX.P1 
. Brarxit to the entry point 
. to "SUBI" minui one byte 
. Thil lervei R(7) pointing 
.to "SUBI" • 



■ PC become* R|3) 
X - 2 



PC b-comet R(7) 



PC - R|7) 



PC becom« R|8| 
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EXIT2: 


RET 


. . nnu> n lu o w j i 


Qi i a 1 ■ 

S\JO£ . 




. . "SUB2 e*9CUtion itarti here 




LDXA 


. . Pick up inline parameter 

. . from caller 

..More code in "SUB2" 




SEX R2 


. . Point R(X) to Hack for return 




INC R2 


..Point to old jX.P) 




BR EXIT2 


. . Branch to entry point 
. . to "3UB2" minui one byte 
. . This leav« R|8) pointing 
. . to "SU32" 






END 


. . End of p'Ogram source 



PC - RI8) 



Register R(2) must point to a free memory area for use 
as a stack. This stack must be large enough to hold two 
bytes for each level of nesting that might occur plus any 
additional bytes that the programmer might choose to 
push onto the stack. Thus, for a program that contains 
five subroutines and the possibility exists that the main 
program might call a subroutine which calls another 
which in turn calls another, then the last subroutine is 
said to be three levels deep. 

Register R(3) is the basic program counter for both 
the main program and the subroutine. So long as the- 
proper SCRT call and return conventions are main- 
tained, the programmer is assured that R(3) is the pro- 
gram counter. 

THe SCRT uses two linking subroutines: one when 
the call operation is to be performed and the other when 
the return from the subroutine is to be performed. 
Registers R(4) and R(5) must be initialized once in the 
program to point to the linking call subroutine and the 
linking return subroutine, respectively. 

Calling a Subroutine 

A call to a subroutine is performed by executing a 
SEP R4 instruction. The two bytes following this SEP 
instruction must contain the address of the subroutine 



Function 



Stack pointer 
Program counter 

Dedicated program counter for call routine 
Dedicated program counter for return routine 
Pointer to the return location and arguments passed by the 
calling program 



Fig. 75 - Register assignment table for standard call and return technique (SCRT). 



Standard Ca!i and Return Technique 

The Standard Call and Return Technique (SCRT) is 
the most advanced technique described in this material. 
It has several advantages over the preceding techniques 
in that : 

1. Tnere is unlimited subroutine nesting capability. 

2. There is no confusion over program counter assign- 
ments. 

3. The passing of parameters to subroutines is well 
defined. 

4. It has a maximum of flexibility in storing working 
registers. 

SCRT is not without its disadvantages, however. They 
are: 

1. It requires additional execution time in calling and 
returning. 

2. It reserves three registers for linkage. 

The specific implementation discussed here may also be 
tailored to suit the preferences of the programmer in 
that additional registers may be saved or restored. 

The SCRT centers around the register assignments 
given in Fig. 75. 



Register 

R{2) 
R(3J 
R{4) 
R(5) 
R(6) 



/ 
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to be called. For example, to call the subroutine labeled 
MULT, the following assembly language statement could 
be employed: 

SEP R4 . . Call multiply subroutine 

,A(f,iULT) . . Call multiply subroutine 

For those subroutines that expect a constant to be 
passed to it as per an inline parameter, the following call 
could be used: 

SEP R4 . . Call type program 

,A(TYPE) . . Call type program 

,TText for Typing' 

,#00 . . Denote end of string with null 

Other methods for passing parameters to a subroutine 
involve the use of a register, a memory area pointed to 
by a register, a reserved area of memory, DF, or Q. Data 
may not be passed via the D register, however, because 
the D register is used by the linking subroutines. 

After a SEP R4 instruction is executed, the following 
events take place: 

1. R(4) becomes the program counter. 

2. The call subroutine starts running in R.(4). 

3. The current contents of R(6) is pushed onto the 
stack. 

4. The contents of R(3) is copied into R(6). 

5. The address of the subroutine being called is 
loaded into R(3). 

6. A SEP R3 starts execution of the called sub- 
routine. 

As a result of the register manipulations, (a) the sub- 
routine being called will run in R(3), (b) register R(6) 
will point back to the data list of inline parameters pro- 
vided by the caller or to the return address for the return 
operation, and (c) because R(6) was saved, the stack will 
have "grown" by two bytes. 



If the subroutine is expecting inline parameters to be 
passed to it, it should execute as many LDA R6 instruc- 
tions as there are bytes in the data list. This execution 
will load the successive data bytes into the D register for 
use by the subroutine and increment R(6) up to the 
proper address for a return operation. If the subroutine 
needs to call other subroutines, it may call by executing 
a SEP R4, etc. As many subroutines in succession as are 
required may be called. 



Returning from a Subroutine 

Once a subroutine has been called and has completed 
its function, control should be returned to the caller by 
executing a SEP R5 instruction: 

SEP R5 . . Return to caller 

After the SEP R5 instruction is executed, the following 
events take ptece: 

1. R(5) becomes the program counter. 

2. The return subroutine starts running. 

3. The contents of R(6) is moved to R(3). 

4. The saved R(6) contents is reloaded from the stack 
into R(6). 

5. The execution of the calling program is resumed 
with a SEP ?3 from the linking program. 



Example 5. Main Program Calling for Unlimited 
Subroutine Nesting. 

This example illustrates the Standard Call and Return 
Technique (SCRT) capable of handling an unlimited 
number of nested subroutines. The register assignments 
are given in Fig. 75. 



Programming Technique: 



Execution starts at location 0000 with R(0) as the program counter. 
Load the address of "MAIN" program into R(3): 



LOAD 'R3YMAIN' . . Lewd A(MA1N) into RI3) 



PC - RIO) 



Load the address of the call routine into R(4): 



LOAD R4\ 'CALL' . . Lo»d AICALL) into R(4| 



PC - R(0) 



Load the address of the return routine into R(5): 



LOAD •RSVRETPGM 1 . . Lojd A(RETPGM) into RIS) 



PC - RIO) 



. . Set stack pointer R(2) to a RAM area: 



LOAD -R2\-STACK' . . Load A(STACK) into RI2) 



PC ■ RIO) 
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To "MAIN" 



SEP R3 



. Execution r«ium« it tabel "MAIN" 



-PC become R|3) 



. GENERAL PURPOSE AREA 
. Place data or subroutine! hers 



To "SUBI- 



•il "CALL' 



From "SUSr 
via "RETPCM* 



to -soar 

v.j -CALL- 



From "SU3V 
Y,a "RETPGW 



MAIN: 



Return via 



-RETPCM- 



To "SUBl" 
via "CALL" 



Return vie 
"RETPGM" 



r 

r 



SUEl 1 : 



SUB2: 



. . "MAIN- program code 



SEP R4; .AiSUSI) . . Call "SUB 1 " 



. "SU31" returns here 
. Mcwe code in "MAIN" 
. program 



SEPR4: J A|SUe2).*l1 . . Call "SU82", and psss the 



.. inline argument {"1 1 1 

. . "SU32" returns here 
..More code in "MAIN" 
. . p/ogram 
BR MAIN . . Start "MAIN" again 



. "SUBl" execution starts here 
.More code in "SUBl" 



SEP R5 



. . RI5l is pointing to "RETPGM" 



LD A R3 



. . "SUB2" execution starts hare 
. . Get parameter from caller 
. . Mora code in "SUB2" 



SEPR4: .A(SU81) 


..Call "SUBl" 


. . More code in "SUB 1" 


SEP RS 


. . RI5) is pointing to "RETPGM" 



PC -R|3) 



PC become! RM) 



PC becomes R(4) 



PC-RI3) 



PC becomes RIB) 



PC - R(3) 



PC becomes R(4) 



PC b-comi R(5) 
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To called program 



Enter "CALL' 



-CALL: 



EXITA SEP R3 



To retu n 



Enter "RETPGM- 



GHI R8 
STXO 
GLO R8 
STXO 
GHI R3 
PHI R6 
GLO R3 
PLO R8 
LOA R6 
PHI R3 
LDA R8 
PLO R3 
BR EXITA 



. . R(3) a pointing to the first 

. . instruction in subroutine. 

. . Push RI6) onto n»ck to 

. . prepare it for pointing 

. . to arguments, end decrement 

. . to free location. 

. . Copy R(3J into R(6) to 

, . save The return address. 

. lave the return address. 

. save the return address. 

. Load the address of subroutine 

.imoR(3) . 

. into R(3) 
. into R(3) 

. Branch to entry point of "SUB1" 
. minul one byte. This leaves R(4) 
. pointing to "CALL" allowing 
. following repeated calls. 



•PC - R(4) 



- EXITR: 


SEP R3 


c 

. . Return to "MAIN" program. 


- RETPGM: 


GHI R6 


. . Copy fi|6) into R(3) 




PHI R3 


. . R|3) contains the return 




GLO R6 


. . address 




PLO R3 


. . addreu 




SEX 2 


. . Point to stack 




INC R2 


• . . Point to saved old R(6) 




LDXA 


. . Restore the contents 




PLO R6 


. . of RI6). 




LOX 


. . of R(6). 




PHI R6 


. . of R(6). 




BR EXITR 


. . Branch to entry point of "RETPGM" 

. . minus one byte. This leaves RIS) 
* 

. . pointing to "RETPGM" for 
. . following repeated alls. 



•PC - R(S) 



Interrupt Service 

The use of the COSMAC interrupt line involves 
special programming considerations. The user should be 
aware of ihe fact that an interrupt may occur between 
any two instructions in a program. Therefore, the se- 
quence of instructions initiated by the interrupt routine 
must save the values of any machine registers it shares 



with the original program and restore these values before 
resuming execution of the interrupted program. 

R(l) must always be initialized to the address of the 
interrupt service program before an interrupt is allowed. 
Fig. 76 illustrates a hypothetical interrupt service rou- 
tine. R(l) is initialized to 0055 before permitting inter- 
rupt. R(2) is a stack pointer, i.e., it addressed the free 
topmost byte in a variable-size data storage area. This 
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stack area grows in size as the pointer moves upward 
(lower memory addresses), much like a stack of dishes 
on a table. Also like the dish stack, it shrinks as bytes 
a,e removed from the top. In the interrupt service 
example of Fig. 76, the stack grew by two bytes as 
X,P, and D were stored on it, and then decreased to its 
original size when D and XR were restored. Such a stack 
is sometimes referred to as a "LIFO" (Last-In-First-Out) 
because the first item removed from the stack is the last 
one placed on it. 

When bytes are to be stored onto the stack by the 
interrupt routine the pointer R(2) is first decremented 
to assure that it is pointing to a free space. In the exam- 
ple shown, location COFO may have been in use when 
the interrupt occurred, so the pointer decrements to 
OOEF to store X,P. When bytes are no longer needed, 
,l -ey are removed from the stack and the pointer is 
...cremented. 

The stack in Fig. 76 is to store the values of X.P, 
and D associated with the interrupted program. If the 



Fig. 76, program execution branches to location 
M(0053). R(2) points at M(OOEE). The LDA (42) in- 
struction at M(0053) restores the original value of D and 
R(2) advances to M(OOEF). The RETURN instruction 
(70) sets IE=1 and restores the original, interrupted X 
and P register values. The next instruction executed will 
be the one which would have been executed had no 
interrupt occurred (unless the interrupt is still present, in 
which case the whole process is repeated). Note that 
R(l) is left pointing at M(0055) and R(2) is pointing at 
M(00F0), as they were before'the interrupt. 

When IE is reset to by the S3 interrupt response 
cycle, fur ther interrupts are inhibited regardless of the 
INTERRUPT line state. This setting prevents a second 
interrupt response from occurring while an interrupt is 
being processed. The instruction (70) that restores origi- 
nal program execution at the end of the interrupt rou- 
tine sets IE=1 so that subsequent interrupts are per- 
mitted. 

Sometimes the programmer needs to control IE 



START 
HERE 

ADDRESS 


BYTE 


OPERATION 


COMMENTS . 


0053 


«2 


EXIT: LDAR2 


RESTORE D 


COM 


70 


RET 


RESTORE X.PAND 








R(2j; ENABLE 


\ 






INTERRUPTS 


0055 


22 


OEC R2 


DEC STACK POINTER 


005 S 


78 


SAV 


OLD X, P ONTO STACK 


0357 


22 


OEC R2 


DEC STACK POINTER 


0058 


52 


STR R2 


OLD ONTO STACK 








SAVE OTHER REGIS- 








TERS IF REQUIRED 








PERFORM "REAL 








WORK" REQUESTED 








BY INTERRUPT 








RESTORE OTHER 








REGS- 








PREPARE TO RETURN 




X 


BR EXIT 
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1 


STORAGE FOR OTHER 








REG. 


OCEE 






STORAGE FOR D 


OOEF 




STACK 


STORAGE FOR T.i.e. 








OLD X.P 


00? 






STACK TOP WHEN 






1 


INTERRUPTED 








OTHER STACX ENTRIES 



Fig. 76 - Interrupt service routine. 



interrupting program will modify any other registers 
(scratchpad or DF), their contents must also be saved. 

After these "housekeeping" steps have been com- 
pleted, the "real work" requested by I he interrupt signal 
can be performed. This work may involve such tasks us 
transferring I/O bytes, initializing the DMA pointer 
R(0). checking the status of peripheral devices, incre- 
menting or decrementing an internal timer/counter regis- 
ter, branching to an emergency power-shut-down 
sequence, etc. 

Upon completion of the "real work", return house- 
keeping must be performed. The contents of registers 
saved on the stack arc now restored. In the example of 



directly. For example, he may want to permit new inter- 
rupts to interrupt the servicing of old interrupts. Or, he 
may want to shut off interrupts during a critical part of 
the main program. 

The RETURN and DISABLE instructions can be used 
to set or reset IE without changing P and performing a 
branch. A convenient method is to set X equal to the 
current P value and then perform the RETURN (70) or 
DISABLE (71) instruction, using the desired X.P for the 
immediate byte. For example, if IE=0, X=5, and P=3, 
the sequence 

E3 SEX R3 . .SetX = 3 

70 RET ' . . Return X to 5, P to 3, 1 ->■ IE, 



va 
56 



User Manual for the RCA CDP1802 COSMAC Microprocessor 



53 .£53 



R(3) + t. 
, . Immediate byte 



^ would h?ve no effect other ttan setting the interrupt 
enable IE. A simi!?' sequence with a 71 instruction can 
! be used to disable interrupts during a critical instruction 



sequence. 



Interpretiye Techniques 



An interpretive system offers the advantages of a 
"higher-level" language without the disadvantages of 
complex translation programs. The idea is to define a 
set of psoudo instructions which are more powerful 
than basic CPU instructions and, consequently, easier 
to program with. Each pseudo instruction is imple- 
mented by a corresponding subroutine. In the simplest 
h >retive system, each subroutine ends with a 
mechanism which passes control on to the next sub- 
routine (i.e., pseudo instruction) to be executed. The 
sequence of pseudo instruction is defined by a pseudo 
program, analogous to the way a program defines a 
sequence of instructions. A pseudo program counter is a 
register which is generally pointing at the next pseudo 
instruction to be executed. Just as with a real program 
counter, pseudo branch instructions may affect the nor- 
ma! sequencing of the pseudo program counter. 

Specifically, let PPC be the pseudo program counter- 
one of the COSMAC registers. Let PC be the normal 
program counter. Suppose that all subroutines begin and 
end on the same page in memory. They may branch to 
other pages, but they eventually come back. Then, a 



pseudo program is nothing more than a series of ad- 
dresses-the low-bylc address of each successive sub- 
routine to be executed. Each subroutine ends with the 
same two instructions: 

LDA PPC . . fetch next address 

PLO PC into PC low. 

These instructions give control over to the next -sub- 
routine. 

Just as with subroutine calls (which they closely 
resemble), pseudo instructions may be followed by argu- 
ments or argument addresses. For example, a (long) 
branch pseudo subroutine would be: 



LBR: 



LDA PPC 
STR STACK 
LDA PPC 
PLO PPC 
LDN STACK 
PHI PPC 
LDA PPC 
PLO PC 



. Put first address byte 

. into the stack. 

. Put second byte 

. into PPC low. 

. Put first byte 

. into PPC high. 

. Go 

. to next pseudo instruction. 



A typical set of pseudo instructions might include 
multiple-precision or floating-point arithmetic functions, 
I/O handling instructions, multi-w3y branches on arith- 
metic comparisons, subroutine linkage routines, and a 
mechanism to drop into standard COSMAC instructions 
whenever necessary. The programmer should choose and 
program a set of instructions suitable to his specific 
application. 

More details and a discussion of alternative interpre- 
tive systems may h<* found in COSMAC Application 
Notes to be provided. 
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This section describes some circuits and suggested 
techniques for interfacing the COSMAC Microprocessor 
CDPi802 with externa] memories, control circuits, and 
input/output devices in various system configurations. 
Reference to the section on Timing Diagrams will be 
helpful in reading this material. 

Memory interface and Timing 

The use of memory interface lines is best described 
by specific examples. Fig. 77 shows the direct intercon- 
nection of a static 32-byte RAM to the CPU. No ex- 
terna! parts are required. The same simplicity in interfac- 
ing is evident in Fig. 78 for a 256-byte static RAM. For 
memorie.s requiring more than eight addressing bits, Fig. 
79 illustrates the interconnections of a static 1024-byte 
RAM to the CPU. The 1024-byte read-write memory 
comprises eight 1024-word by 1-bit CDP1821 RAM's. 
These static RAM's, requiring only a single power sup- 
ply, are easy to use. Ten memory address bits are re- 
quired to select 1 out of 1024 memory byte locations. 



The high-order byte (A.l) of a 16-bit memory address 
appears on the memory address lines MA0-7 first. The 
two least significant bits of A.l are strobed into the 2-bit 
address latch by timing pulse TPA. Fig. 80 shows the 
memory read and write timing. For a more detailed tim- 
ing diagram including set-up and settling time delays, 
refer to the data bulletin for the CDP1802. 

The low -order byte (A.0) of a 16-bit COSMAC 
memory address appears un the MA 0-7 lines after the 
high-order bits have been strobed into the address latch. 
Latching all eight A.l bits would permit memory expan- 
sion to 65,536 bytes. Chip select decoding would have 
to be added to the latch output for memory expansion. 
The MA 0-7 lines may also require buffer circuits to 
reduce the load on them to achieve high speed. 

The state of the KM and MRD lines determines 
whether a byte is to be read from the addressed memory 
location, written into it, or neither operation performed. 
Fig. 81 tabulates the operation of the memory control 
lines. Note that the MRD and MWR lines are active low. 
The CPU controls the destination of the memory output 
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Fig. 78 - Interface for the CDP1822 static RAM to the CDP1802 microprocessor in a 
256-byte HAM system. 



byte when it appears on the data bus. The byte may be 
strobed into an internal CPU register or into an external 
I/O register. During a WRITE cycle, the memory output 
is in a high-impedance state. The CPU or I/O circuits can 
then place a byte to be stored in memory on the bus. A 
negative-going MWK pulse will cause the data byte to be 
written into the addressed memory location. Eight bus 
pu!!-up resistors should be provided to place the bus in a 
known state when it is not being driven. 

Figs. 82 and 83 show interfacing for the CDP1802 
with various other memories in the 1S00 series of parts. 
Other industry standard RAM's and ROM's are readily 
accommodated by the CDP1802's general-purpose inter- 
face lines. Access tune, however, must be consistent with 
clock frequency. The data bulletin for the CDP1802 
gives curves relating access time, clock frequency, and 
instruction cycle. For example, a 4-?»lHz clock will re- 



quire a memory having a maximum access tune of 900 
nanoseconds. The time required by the CPU and internal 
gating is also specified on the data sheet. 

If a memo ry does not have a 3 -state high-impedance 
output, MRD is useful for driving memory-bus separator 
gates; otherwise., it is used to control 3-sta te outputs 
from the addressed memory. A low on MRD indicates a 
read cycle; the low MRD line enables the mcrnory- 
output-bus gates during the read cycle. For various 
memory systems, the MRD" signal and the MWR pulse 
polarity and width may require modification by external 
circuitry. 

Segments of ROM's can be attached in the same man- 
ner as RAM's but with the write controls omitted. The 
CDP1831 ROM is especially easy to use because address 
latching is provided on chip to latch the 8 most signifi- 
cant bits of a 16-bit address. The on-chip decoder is 



V.A 9 



CO4042 
LATCH 



MA 9 

STATIC RAM 

im* BYTES 
EIGHT CDf-1821'i 
(1024 X 1! 

MWR 

CS 



D IN O OUT 



3H 




MA 0-7 
8 



CPU 

CDP1802 



MRD 



DATA BUS 7 



V CC BUS 
9 9 9 PULL UP 
S J I RESISTORS 
< I I (22KU) 
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mask programmable which enables placement of a 512- 
byte memory block anywhere within 65 kilobytes of 
memory space. Note that the chip enable output signal 
goes high when th'e device is selected. It is intended as a 
chip-select control for small (up to 256-byte) RAM 
systems. 

Dynamic RAM's can be used with appropriate refresh 
circuits. Because the CDP1802 circuitry is static, the 



MA 






CPU 




CDP1802 


MWR 




MRO 





DATA BUS 7 



I O O BUS PULL UP 
; | [ RESISTORS 
• J J (22 Kill 



Fig. 82 - Interface for the CDPJ827 static RAM to the CDP1802 microprocessor In a 
256-byte RAM system. 



70 



_ ^_ User Manual for the RCA CDP1802 COSMAC Microprocessor 

l , 



clock may be stopped and restarted for asy nchronous 
memory operation if required, or the WAIT input may 
be used to signal a Data Ready condition. For additional 
information on this subject, refer to the following sub- 
section on "Control Interface." 



Control Interface 

The COSMAC Microprocessor CDP1802 has an 
internal oscillator that works with a crystal connected 
between the CLOCK and XTAL terminals. If desired, 
however, an external oscillator may be used and fed into 
the CLOCK input. If an exter nal osc illator is used, no 
connection is required at the XfAL terminal. (Note: 
care must be taken not to load the XTAL.) Any type of 



If the WAIT line is brought low (with CLEAR high), 
the CPU stops operation cleanly on the next negative- 
going transition of the clock (Pause mode). Output sig- 
nals are held at their values indefinitely. This state is 
useful for several purposes. Using the WAIT line, the 
CPU can be easily single-stepped for debugging purposes 
or, if stopped early in the machine cycle, the CPU can 
be held off the data bus to allow for multiprocessor 
systems, etc. Also, the WAIT line can be used as a data- 
ready signal from a slow memory or peripheral, or 
signals TPA and TPB can be stretched. When the WATT 
line is returned high, the machine resumes running on 
the next negative-going transition of the clock input. 
The WAIT signal does not inhibit the on-chip crystal 
oscillator. DMA's and Interrupts are not acknowledged 
in the Pause mode. 
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Fig. 83 - Interface for a mixed ROM/RAM system. 



single-phase clock may be used so long as the rise and 
fall times of the clock pulse are less than 15 micro- 
seconds. Each machine cycle consists of eight clock 
pulses, and each instruction requires two or three 
machine cycles, "thus, with a 6.4-MHz clock frequency, 
a machine cycle of 1.2S microseconds could be achieved, 
and instructions would be executed in 2.5 to 3.75 micro- 
seconds depending on the instruction. 

During normal operation, the CLEAR and WAIT lines 
are both held high: A low level on the CLEAR line will 
put the machine into the'.resct mode with- 1, N, X, P, 0. 
Data Bus = 0. and IE = I. Actually, X, P, and R(0) are*) 
reset during a special SI cycle (not available to the pro- 
grammer) immediately following transition from the 
reset mode to any of the other modes (load, run, or 
pause). T he cloc k mu st be r unning In effect this cycle. 

If the CLEAR and WAIT lines arcboth heldlow, the 
machine enters the load mode. This mode allows input 
bytes to be sequentially loaded into memory beginning 
at M(0000). Input bytes can be supplied from a key- 
board, tape reader, etc., by way of the DMA facility. 
This feature permits direct program loading without the 
Use of external "bootstrap" programs in ROM's. 



Fig. 84 shows one circuit using standard devices from 
the CD4000 series for controlling the run and load 
modes of the CDP1802. Note the power-on reset 
feature. To load and start a program, the sequence of 
operations would be as follows: First, depress the reset 
and then the load buttons. The CPU is now ready to 
load by means of the . DM A channel. When loading is 
completed, depressing the reset and then the run buttons 
will start program execution at M(0000) with R(0) as 
the program counter (after one machine cycle). If a 
DMA request is present when the run switch is turned 
on, the machine will go into the DMA slate immediately 
with R(0) as (he program counter. The user should 
therefore inhibil DMA externally tint il the program has 
changed to a program counter ililTercnl from R(0). 
Interrupts, however, are disabled until the first instruc- 
tion or DMA request is executed. This delay allows the 
programmer to place instruction 71 and 00 in i lie first 
two memory bytes to inhibit interrupts until he is ready 
for them. The combined effect of ihc two instructions is 
to set IE = 0. Interrupts must not occur, however, when 
the machine is in the load mode because they will force 
the machine into an anomalous running state. Fig. 85 
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Fig. 84 - Simple control interfere for CDPI802 microprocessor. 



shows the sequence of events and states involved in 
loading and running a program. 

Another circuit that can be used for single-stepping 
the microprocessor (one machine cycle per switch de- 
pression) is shown in Fig. 86. This capability is often 
useful as a debugging aid. 

Fig. 87 provides a summary of the modes discussed, 
the control levels, and the characteristic features of these 
modes. It is evident that the run mode can be entered 
from either the reset or the pause mode. 



I/O interface 

The three basic ways in which the CPU can com- 
municate with I/O devices are programmed I/O, inter- 
rupt I/O, and Direct Memory Access (DMA). In the 
programmed I/O mode, all data transfer is controlled 
and timed by the program. In the interrupt I/O mode, 
the CPU r esponds to an I/O generated signal. In the 
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DMA mode, a direct high-speed data channel- is estab- 
lished between memory and I/O device. The I/O device 
'"steals" execution cycles from the CPU and transfer 
data during these time slots. 

Fig. 88 gives a summary of the interface lines pro- 
vided by the CDP1S02 microprocessor. The large 
number of dedicated lines available offers both economy 
and flexibility in I/O system designs. 

The following paragraphs indicate a few ways in 
which I/O data transfer can be accomplished under the 
three basic modes of operation. Throughout these exam- 
ples, IC's from the CDP1800 and CD4000 series of stan- 
dard parts are used. Devices from the 1800 series belong 
to a growing family of dedicated parts designed specifi- 
cally to interface with each other and with the CDP1802 
Microprocessor for optimum system design. A broad 
choice of standard parts from the 4000 series is also 
available for flexible and inexpensive system operations. 
For detailed information on these devices, the reader 
should refer to the latest RCA Integrated Circuits 
DATABOOK. 

Programmed I/O — Direct Selection of I/O 
Devices 

One input port only. When I - 6 and N = 9, A, B, C, 
D, £, or F, a byte on the data bus is written into the D 
register and the memory location addressed by R(X). 

The simplest form of input to the microprocessor 
utilizes one of the four externa! flag lines: EFl, "EFT, 
EF3, or EF4. A low on a flag line places it in its true 
state. The short branch instructions 34, 35, 36, 37, 3C, 
3D, 3E. and 3F allow programs to determine the states 
of these flag lines. 

Fig. 89 illustrates one method of using a flag line 
(EFT in this case) to signal the CPU and initiate a byte 
transfer into memory and D register. In this circuit, 
turning the switch on sets EF1 low and turning it off 
sets EFT high. The flip-flop eliminates switch b ounc e. 
Assume first that the switch is off and, therefore, EFT = 
I. The short branch instruction 3C will test the status of 
the EFl flag. The 3C instruction executes a short branch 



if EFl = (i.e., EFl = 1), in this case to the branch 
address XX0A. So long as the switch is off, the program 
will continue to test the EFl flag and execute a branch 
to XX0A during every instruction cycle. Assume next 
that t he s witch is activated so that EFT becomes true 
(i.e., EFl = 0). Execution of 3C now requires that the 
next instruction EA be executed. Tins instruction sets 
up R(A) as a data pointer and, in this example, it has 
been preloaded with address XXI A. Instruction 69 is an 
input command and loads the byte on the bus into D 
and the memory location addressed by R(A), (XXI A). 

The switch of Fig. 89 might be replaced by a Tele- 
type* output relay. The opening and closing of this relay 
contact represent the bit-serial teletype character code. 
A COS.MAC program could interpret the sequential 
states of the EFl line to provide an extremely simple 
bit-serial interface. (The Terminal Interface card and the 
Utility Program described in Manual MPM-203 give a 
practical illustration.) 

Fig. 90 also shows how input bytes can be read into 
memory in conjunction with a flag line, but the bylc is 
now entered under CPU control. In this example, the 
user's strobe asserts one of the EF (lags which is being 
monitored by a branch instruction in the program. A 
byte is latched into the register in a high to low transi- 
tion of the strobe pulse and generates a service request. 
When a low is detected on EFl , the program branches to 
an input instruction 69 (I = 6 and N = 9). During execu- 
tion of 69, the three N bits available at the interface are 
valid. The NO line, which was low, is active high during 
the execute cycle. When the CPU responds with an input 
instruction and the NO line goes high, the input byte is 
enabled onto the data bus. 

During this machine cycle, the CPU generates a low 
MWR pulse which writes the valid byte or. the bus into 
memory. For further details on input instruction tim- 
ing, refer to the section on Timing Diagrams. Note that 
the EF 1 line is forced high (the service request is reset) 
at the end of the valid NO bit to assure that only one 
byte is entered per strobe pulse. 

The input byte might be the byte output of a paper- 
tape reader, keyboard, or other input device. The input- 

•RegLstered trademark. Teletype Corporation. 
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Fig. 90 — Direct selection of I/O devices — one input port. 



byte-transfer rate should be consistent with the speed 
the program samples the flag line and executes input- 
byte-transfer instructions. 

One output port only. When I = 6 and N = 1,2,3,4, 
5, 6, or 7, the memory byte addressed by R(X) is placed 
on the data bus. The three N bit lines are valid during 
the execution cycle and indicate that an I/O operation 
is performed. The M(R(X)) byte appears on the data 
bus before the timing pulse TPB occurs and remains on 
the bus until after the TPB line returns to its low state. 

Fig. 91 shows simple logic for transferring a byte 
from memory to an output register under program con- 
trol. If a 61 instruction is execuicd, the NO line becomes 
high during the execute cycle and C3n be used with the 
timing pulse TPB to strobe a valid data byte into the 
output register. The user is then free to enable the out- 
put of the register. For more information on output 
.istruction timing, refer to the section on Timing Dia- 
grams. 

Fig. 92 shows how an output instruction, in this case 
61, might be used to set a byte into a two -hex-digit out- 



put display device. Each HP5082-7340 display chip con- 
tains a 4-bit register, a decoder, and a hex LED display. 
During the execution cycle of instruction 61, when the 
NO bit is valid, TPB will strobe valid data into the two- 
digit hex display. 

A COSMAC program can be written to simulate a 
free-running two-digit decimal counter. Each two-digit 
count can be placed in the output display of Fig. 92. 
The switch in Fig. 89 can be used to start and stop the 
counter. If the switch is in the "ON" position, counting 
proceeds (00-99). When the switch is turned off, count- 
ing stops and the current value of the count is displayed. 
Turning the switch "ON" again will re-initiate counting, 
starling at the value displayed. A portion of a possible 
"counter program" is shown in Fig. 93. In this example, 
the logic in Fig. 92 must be modified with the MRD 
line to distinguish between input and output instruc- 
tions, as discussed in the material following. 

One input and one output port. Fig. 94 shows how 
the logic in Figs. 90 and 91 can be combined to pr ovide 
byte transfers in either direction. The level of the MRD 
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Fig. 93 — Portion of a two-digit decimal counter program. 
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line determines direction of data flow. During an input 
instruction execute, the CPU is in a memory write cycle 
with MRD high, i.e., the input register is enabled to the 
bus and the input byte is read into memory when M~RT) 
is high. During an output instruction execute, the CPU 
is in a memory read cycle with MRD low and, hence, the 
input register, is disabled from the bus. At TP8, valid 
data is strobed from the bus into the output register. 

More than one I/O device - Input ports only. The 
simple byte logic in Fig. 90 can be expanded up to three 
I/O ports with direct selection of the devices, as shown 
in Fig. 95. The three N bits are valid during I/O opera- 
tion; hence, instruction 69 selects port I, 6A selects port 
H, and 6C selects port III. The user's strobe will activate 
an EF flag and enter a byte into the register. 

More than one I/O device - Output ports only. The 
^mple logic described in Fig. 92 can be similarly ex- 
.nded to handle three pairs of display digits, as shown 
Ln Fig. 96. Each digit pair is selected by one of the N 
lines, depending on the chosen instruction. Instruction 



61 selects digit pair 
selects pair D2. 



DO, 62 selects pair DI, and 64 



More than one I/O device - Both input ports and 
output ports. The circuits in Figs. 95 and 96 were de- 
signed for data flow in or out, respectively. Three I/O 
ports under control of the N lines can easily be wired up 
by expanding the logic in Fig. 94. 

Another simple three-port I/O system but with a 
CD4000-series register is shown in Fig. 97. In this 
circuit, the I/O device has master-slave flip-flops. Both 
input and output data can be disabled, and data is 
strobed in on a leading edge of the clock pulse when the 
input is enabled. NO and a read level on MRD will enable 
data from the bus into output register #1 while the 
input register #1 is disabled from the bus. A valid byte is 
strobed from the bus into the output port a t TPB. Dur- 
ing an input instruction, a high level on MRD enables ihe 
input port #1 to the bus. Similarly, Nl controls I/O 
ports #2, and N2 controls I/O ports #3. 
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Programmed I/O — Orva-Level I/O System 

The I/O interface systems described so far are appli- 
cable for small systems (up to three I/O ports) where the 
N lines can be used directly to select or control I/O de- 
vices. Jf more than three I/O devices are required, the N 
lines can be decoded to specify up to 1 of 7 different 
I/O ports or channels. Fig. 93 illustrates this approach. If 
line 1 is selected from the decoder, for instance by exe- 
cuting input instruction 69, the input register is enabled 
to the bus because MRD is high during memory write 



cycle. Decode line 1 will also be active high during an 
output instruction, 61 , but MRD is low during memory 
read cycle, disabling the input register from the bus. At 
TPB, the valid byte from memory is strobed into the 
output register. 

As discussed earlier, the user's strobe or write signal 
can be used to activate an EF flag or the interrupt line. 
An I/O request can be acknowledged by OR-ing the N 
lines. If the interrupt is asserted, the two state-code lines 
SCO and SCI are both high, acknowledging an interrupt 
(S3) cycle. 
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Fig. 97 — Direct selection of I/O devices — one of three input ports or one of three 
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Programmed I/O - Two-Level I/O System 



The COSMAC architecture imposes no theoretical 
limits on the number of I/O ports which the CPU can 
accommodate. Systems iarior than those discussed up 

r till now, however, require an additional level of de- 

licoding. 

Fig. 99 shows one possible Implementation of a large 
J/O system which handles 256 input and 256 output 
"ports. A 61 instruction is first executed to place an 8-bit 
device-selection code in the I/O device-select register. 
Subsequent execution of a 62 instruction will send an 
"frS-bit control code to the selected output port or chan- 
£nel. Control codes can be used to siart or stop electro- 
mechanical devices, set up specific modes of operation, 
^et -* v hen the 8-bit I/O device-select register specifies an 
foui, A device, execution of a 63 instruction will cause 
- the transfer of an output data byte to the selected 
device. 



After an input device is selected, a 6A instruction 
could be executed to obtain a status byte from a 
selected device. Subsequent execution of a 6B instruc- 
tion could store an input byte in memory. The remain- 
ing I/O instructions could be used to control other Sys- 
tem functions either directly or under control of the 
device-select register. 

Note that the I/O register has two chip-select inputs; 
hence, an output register is selected only when both the 
address decode line and MRD are true. A byte can only 
be strobed into the selected output register during TPB 
when a command decode line is true. In order to select 
the input register, both the address decode line and t he 
command decode line must be asserted when MRD is 
not true. 

In summary, a byte on the data bus can be a device- 
select code, a control byte, a status byte, read data, 
write data, etc. To describe or interpret the byte on the 
bus, the decoded outputs of the three N bits are used. 

The above examples under "I/O Interface" indicate 
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only a few of the ways in which I/O instructions can be 
implemented. The I/O interface lines can be used in a 
great variety of ways, limited only by the ingenuity of 
the system designer. 

DMA Operation 

The I/O examples described above require that a pro- 
gram periodically sample I/O device status. These tech- 
niques also require several instruction executions for 
each I/O byte transfer. In many cases it is desirable to 
have I/O byte transfers occur without burdening the 
program or to transfer data at higher rates than possible 
with programmed I/O. A built-in direct-memory-access 
(DMA) facility permits high-speed I/O byte transfer 
operations independent of-normal program execution. 

During DMA operation R(Q) is used as the memory 
address register a nd should not be used for other pur- 
r-^es. Two lines, DMA-IN' and DMA-OUT, are used to 
i est DMA byte transfer to and from the memory. 
Also, a specific code is provided on the state code lines 
(SCO, SCI) to indicate a DMA cycle (S2}. 



mal fetch -execute sequences. If the DMA-IN line goes 
low during an instruction fetch cycle (SO), then the 
normally following execute cycle (SI) will still be per- 
formed. Following this execute cycle (SI), a speciaJ 
DMA cycle (S2) occurs. If the DlvfXTN" line goes low 
during an instruction execute cycle (SI), then the DMA 
cycle (S 2) will follow immediately after SI. If the 
DMA-IN line is reset to its high state during the DMA 
cycle (S2), then the deferred next instruction fetch 
cycle (SO) will be performed following the S2 cycle, as 
shown on Fig. 100. 

An S2 cycle is indicated by a low SCO line and a high 
SCI line. This condition is used to place a DMA input 
byte onto the bus, as shown. For further details on 
timing, see the section Timing Diagrams. The S2 cycle 
stores the input byte in memory at the location ad- 
dressed by R(0). R(0) is then incremented by 1 so that 
subsequent S2 cycles will store input bytes in sequential 
memory locations. S2 cycles do not alter the sequence 
of program execution. The program will, however, be 
slowed down by the S2 cycles that are "stolen". The 
concurrent program must, of course, properly use R(0) 





DMA-IN ACTION 
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DMA-OUT ACTION 
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DiviA-iN 

Fig. 100 illustrates the manner in which DMA-IN 
might be implemented. The leading edge of an enter 
pulse will clock an input byte into the register and acti- 
vate the DMA -IN re quest. 

A low DMA-IN line automatically modifies the nor- 
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It may examine R(0) and the memory area involved to 
observe the course of the data transfer. The program 
must also set R(0) to the address of the desired first 
input byte location in memory before permitting a DMA 
input operation. 
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So far, single byte tran sfer per enter request has been 
discussed.' If the DM A-IN' rem ains low, S2 cycles v/ffl be 
performed until the DMA-IN goes high. In this mode of 
block transfer, the reset logic in Fig. 100 must be modi- 
fied.' The DMA mode permits a maximum I/O byte 
transfer rate of one byte per machine cycle which, with 
two microseconds per instruction cycle time, amounts to 
a transfer rate of one megabyte per second. 

The DMA-IN feature, in conjunction with CLEAR 
and WAIT signals, p rovides a buiit-in prcT-am load 
mechanism. A low cn CLEAR and a high on WAIT puts 
the CPU in the RESET mode. The CPU now idles (SI 
state) with R(0) = 00 00. T he LOAD mode is next 
entered by bringing the WAIT line low (CLEAR = L and 
WAIT = L). This mode allows input bytes to be sequen- 
tially loaded into memory beginning at M(0000). Input 
bytes can be supplied from a keyboard, tape reader, etc. 
via the DMA-IN facility and circuitry similar to Fig. ICO. 
details on timing refer to the material in this section 

'Control Interface. " 

DMA-OUT 

A low on the DMA-OUT line causes S2 _eycles to 
occur in a similar manner as a low on t hs DMA-IN line. 
The S2 cycle caused by a lew 0:1 the DMA-OUT line 
places the memory byte addressed by R(0) on the bus 
and increments R(0) by i. DMA output bytes can be 
strobed into an output device by TPS, as shown in Fig. 
10!. The program must set R(0) to the address of the 
first output byte of the desired memory sequence before 
the DMA transfer request occurs. For details on DMA- 
CUT timing, refer to the section on Timing Diagrams. 

Note: In the event of concurrent DMA and INTER- 
RUPT requests, DMA-IN has priority followed by DMA- 
OUT and then INTERRUPT. 
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Interrupt i/O 

The interrupt mechanism permits an external signal 
to interrupt program execution and transfer control to a 
program designed to handle the interrupt condition. This 
function is useful for responding to system alarm condi- 
tions, initializing the DMA memory pointer, or, in 
general, responding to real-time events less urgent than 
those handled by DMA but more urgent than those 
which can be handled by sensing external flags. 

A low on the [ STTTf RTTLTPT line causes an interrupt 
response cycle (S3) to occur following the next SI cycle, 
provided the IE flip-Hop is set. Execution of an S3 
cycle is indicated by a high on both the SCO and the 
SCI lines. 

Fig. 102 shows a typical interrupt circuit. The flip- 
flop is reset during the S3 cycle. During the S3 cycle, the 
current values of the X and P registers arc stored in the 
T register. P is then set to 1 , X to 2, and IE to 0. Follow- 
ing S3, a normal instruction fetch cycle (SO) is per- 
formed. The S3 cycle, however, changed P to 1 so that, 
next, the sequence of instructions starting at the 
memory location addressed by R(l) will be executed. 
This sequence of instructions is called the interrupt serv- 
ice program. It saves the current state of the COSMAC 
registers such as T, D, and possibly some of the scratch- 
pad registers, by storing them in reserved memory loca- 
tions. DF must also be saved if the interrupt service pro- 
gram will disturb it. The service program then performs 
the desired functions, restores the saved registers to their 
original states, and returns control to execution of the 
original program. Special insiructions RETURN, DIS- 
ABLE, and SAVE (70, 71, and 78) facilitate interrupt 
handling. These instructions are described in the sections 
on Instruction Repertoire and Instruction Utilization. 
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Their use is illustrated in the section on Programming 
Techniques under the heading "Interrupt Service." 

The COSMAC Microprocessor also provides a special 
one-bit register called Interrupt Enable (IE). When IE is 
ait to "0", the state ot" the interrupt line is ignored. IE is 
set to "I" in the reset mode. IE can be set to "I" or "0" 
by RETURN and DISABLE instructions, respectively. It 
is automatically set to "0" by an S3 cycle, preventing 
subsequent interrupt cycles even if the fi7rE"R~RTjPT 
line stays low. The program must set IE to "1 " to permit 
subsequent interrupts. Setting IE to "1" takes place 
automatically when the program executes the RETURN 
•V^'ruction. Sharing the INTERRUPT line with a 
ber of interrupt signal sources is possible. 

When the interrupt facility is used in a system, R(l) 
must be reserved for use as the interrupt service program 



counter, and R(2) is normally used as a pointer to a 
storage area. The latter may be shared with the main 
program if appropriate conventions are employed, as 
described in the section on Programming Techniques. 

System Configurations 

Parallel I/O Interface 

Fig. 103 shows the CPU interfaced to other parts 
members of the 1800 family. Only five parts plus a 
crystal are required to interface directly in a simple and 
efficient system configuration. The RC network con- 
nected to CLEAR is optional and provides power-on 
reset. This basic system implementation can easily be 
expanded for larger memory capacity as shown in this 
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section under the heading "Memory Interface and 
Timing." 

More I/O ports can be added by following one of the 
approaches outlined under "Programmed I/O." Several 
N bits can be used directly for I/O control, or they can 
be decoded for either one- or two-level I/O systems. 

The byte I/O register can be configured as either 
input or output port by the level on the MODE control. 
When the register is used as an input port, data is latched 
into it by a low level on_the clock line. The negative 
transition of clock sets SR = 0, which can be used as a 
service request to the microprocessor. Data is read out 
of the port onto the data bus when the chip is selected 
(CS1 ■ CS2 = 1), and the negative transition of CS1 • CS2 
resets the service request (S~R = 1). 

When the byte I/O register is used as an output port, 
i.e MODE control = H, data is strobed into the register 
fr( the bus by CS1 -CS2-TPB = 1. In the output mode, 
data is enabled out of the port at all times. 

Serial I/O Interface 

Using EF input and Q output. Fig. !04 shows a sim- 



ple, serial interface for a COSMAC-based computer 
system. The sequential logic states of one of the EF lines 
may represent a bit-serial character. A software program 
can then interpret these logic levels and assemble the bits 
into one-byte data words in memory. 

In an analogous manner, SEQ and REQ instructions 
in the program can generate high and low levels on the Q 
output line for serial transmission of a byte from mem- 
ory. This method can be used for interfacing a Teletype, 
printer, or any peripheral with a serial interface. A typi- 
cal interface circuit betv/een the peripheral and the CPU 
is shown in the Terminal Board for the Prototyping 
Development System described in Manual MPM-203. 

Another illustration of Q as an output under program 
control is given in Fig. 105. This minimum system con- 
figuration shows a 4-bit digital combination lock. The 
status of the four manual switches or buttons represent- 
ing a combination is tested by short branch instructions. 
If the combination is correct, the program sets Q = 1, 
thereby activating the solenoid of an electric lock. 

The basic program with sixteen possible combinations 
can be enhanced by various additions. For instance, the 
correct combination must be entered in a certain 
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Fig. 104 — System configuration for serial I/O interface. 
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sequence, or the code must be set within a minimum 
time period. 

Discussed earlier were I/O systems of varying com- 
plexities in which the I/O ports were selected either 
directly or through one or two levels of decoding. In this 
context, the digital combination lock represents the 
lov/est order of complexity. No selection is required and 
no input or output register is necessary. 

Using universal asynchronous receiver-transmitter. A 
more sophisticated and powerful approach to serial 
interfacing than the one shown in Fig. 104 is outlined 
below. The program itself is relieved of the task of for- 
matting and control, and these functions are taken over 
by a dedicated hardware circuit. 



(optional), and stop bits (1, \V>, or 2), as illustrated in 
Fig. 107. The receiver converts a serial input word with 
start, data, parity, and stop bits into parallel data. It veri- 
fies proper code by checking parity and the receipt of a 
valid stop bit. Both the receiver and transmitter arc 
double buffered. 

Although the receiver and transmitter can operate 
with separate data buses, if the MODSF ' . I ine is high, tiie 
UART is directly compatible with COSMAC and bidirec- 
tional data transfer on a common bus. 

There are four registers under program control in the 
UART. One is loaded from the bus in the transmit 
mode, one is read to the bus in the receive mode, a Con- 
trol register is loaded from the bus at initialization, and a 
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Fig. 105 — System configuration for asynchronous serial data communication interface. 



Fig. 106 shows the CDP1854, a CMOS Universal 
Asynchronous Receiver-Transmitter (UART), interfaced 
to the CPU in a typical data communication application. 
The UART consists of a receiver and transmitter de- 
signed to provide the necessary formatting and control 
for interfacing serial asynchronous data to and from 
peripheral devices. The receiver-transmitter is capable of 
full duplex operation and is externally programmable. 

The transmitter converts parallel data to a serial word 
containing the data (5-8 bits), a start bit, a parity bit 



Status register is read in the receive mode. The two-bit 
code on RRT) and RSEL determines which register is 
selected and the direction of data flow. Refer to the 
truth table in Fig. 103. 

The UART is enabled to the data bus when the three 
chip selects are asserted. Therefore, by decoding, a large 
number of UART's can operate in a system on the same 
bus. 

Fig. 106 illustrates one possible way of interfacing 
the UART and the CPU. One of the N bits selects the 
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cnip, and ;he two other N bits select register and receive/ 
transmit mode. A typical operation might be as follows: 
The control register is first loaded from memory 
under program control, for instar. r e, through executing 
output instruction 65. The individual bits in the control 
byte set up the system mode according to the bit pat- 
tern. The bit assignments are listed in Fig. 109. The pro- 
gram determines if the system operates with parity or 
not; if parity, odd or even; how many stop bits; the 
number of bits in the data word; etc. For instance, a 
high in bit position will inhibit parity generation; or, 
if transmit break is present, the serial-data-out line is 
held low. 

Transmitting a character is initiated by executing, for 
instance, output instruction 64. During the execute 
N2 selects the chip and Nl and NO select the 
1(«nsmttter Holding Register (THR), which is loaded 
from the bus at TP3. When the byte has been transferred 
to the Transmitter Shift Register (TSR) for eventual 
serial transmission (on SO), the Interrupt line is asserted 
to indicate that TKR is empty and a new character may 
be loaded. Reading the Status Register will also provide 
this information. 

In the receive mode, a serial character is entered on 
the SI line and shifted into the Receiver Shift Register. 
When this register is full, the byte is transferred to the 
Receiver Holding Register (RHR) and a Data Available 
flag is generated, which is one of the status bits. Before 
accepting the character, the program would typically 
read the Status Register. The bit assignments of the lat- 
ter are shown in Fig. 110. The program can therefore 
determine if, for instance, there is parity error or if a 
complete character has been received and is ready for 
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Fig. 108 — Truth table for selecting chip and registers 
vjith the N bits. 



transfer over the bus to memory. 

Some of the status bits, if set, will also generate an 
interrupt condition. The Status Register in this example 
is read by executing input instruction 6F. If the received 
character is acceptable, the input in struct ion 6D will en- 
able the byte onto the bus, and MWR writes it into 
memory. Upon reading of data from the UART, the DA 
status bit is automatically reset. If another character is 
received before the previous one is icad out, an overrun 
condition is signaled. 

Flexibility in system operation is enhanced by a few 
additional signal lines. The DA and RTHR flags arc 
brought out separately and could, for i nstan ce, signal the 
CPU over the EF lines. Clear to Send (CTS) and Request 
to Send (RTS), in addition to the two peripheral status 
lines IP1 and 1P2, facilitate "hand-shaking" with 
modems and peripherals. 
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Fig. 109 - Bit assignments for control register. 



DATA AVAILABLE 
OVERRUN ERROR 
PARITY ERROR 
FRAMING ERROR 
PERIPHERAL STATUS BIT 1 
PERIPHERAL STATUS BIT 2 
TRANSMITTER SHIFT REG. EMPTY 
TRANSMITTER HOLDING REG EMPTY 



Fig. 1 10 - Bit assignments for status register. 




The following topics illustrated with timing diagrams 
are covered in this section. 

1. Input instruction timing. 

2. Output instruction timing. 

3. DMA-IN timing. 

4. DMA-OUT timing. 

5. Instruction set timings. 

Input Instruction Timing 

Fig. Ill provides the timing relationships for input 
instructions. An input instruction will permit a byte 



from an external device to be written into memory and 
the D register: 

BUS - M(R(X)). D 

The instruction 69, for instance, will be fetched from 
memory during state SO when the CPU asserts MRt) and 
reads the instruction into the I and N registers. The in- 
struction will be executed during the next machine 
cycle, state SI , which is a memory write cycle. The CPU 
generates an active low SlWR pulse during this cycle 
which will strobe an in put byte from the data bus into 
memory. A high MRD level during the memory write 
cycle will also disable the memory output during this 
period. 
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Fig. 111 — Input instruction timing. 
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During the execute cycle when I = 6 and N = 9, A, B, 
C D, E, or F, the three low-order N bits are available 
arid can' be used for enabling a byte onto the data bus 
from the input device. 

Output Instruction Timing 

Fig. 112 provides the timing relationships for output 
instructions. An output instruction wit! permit a stored 
byte in memory to be read out to an externa] device: 

M(R(X))-*8US;R(X) + 1 

The instruction 61, for instance, will be fetched from 
memory during state SO when the CPU asserts MRD and 
reads the instruction into the I and N registers. The in- 
struction will be executed duing the next machine 1 
cycle, state SI, which is now a memory read cycle. 

MRD is during the latter cycle once more asserted 

.1 enables the output from the memory onto the bus. ! 
Data is valid after the access time has elapsed. The valid 
data from memory can next be strobed into the output 
device by a user-geneiated Strobe. Data will always be 
valid when TPB, the N bits, and MRD signals are true. 

The three N bits are valid during the execute cycle 
when 1 = 6 and N = i , 2, 3,4,5, 6, or 7 and can be used 
for enabling a byte from the data bus into the output 
device. 

DMA- IN Timing 

Fig. 1 13 provides the timing relations for DMA-EN 
operation. When DMA-lN is asserted, a byte on the data 
bus from an external device is written into memory at 
the location specified by the register R(0): 

BUS-M(R(0)), R(0)+ 1 



DMA-IN is a user-generated signal that can be asserted 
arty time, but the CPU will always complete its current 
instructio n cycle b efore it enters the DMA cycle or state 
S2. The DMA-IN request is sampled internally during 
TPB and the end of an Sl,S2,or S3 state. Note that the 
last execute cycle before the DMA cycle can be either a 
memory read, a memory write, or a non-memory cycle. 
When the CPU enters the DMA state following DMA-IN. 
it enters a memory write cycle. Memory output is dis- 
abled by a high MRD level, and a low MWR pulse is 
generated which will write valid data on the bus supplied 
from the input device into memory. 

During S2, MRD is high and will disable memory out- 
put to the data bus. If the DMA-IN" request goes away 
during S2, the CPU will next execute a fetch cycle and 
complete the next instruction cycle which had been de- 
ferred. 



DMA-OUT Timing 

Fig. 114 provides the t iming rel ations for the DMA- 
OUT operation. When DMA-OUI" is asserted, a byte 
stored in memory at the location specified by register 
R(0) is read out to the data bus and can be strobed into 
an external device: 

M(R(0))-BUS,R(0)+ 1 

DMA-OUT is a user-generated signal and can be 
asserted any time, but the CPU will always complete its 
current instruction cycle before it enters the DMA cycle 
or state S2. The DM A -OUT request is sampled internally 
during TPB and the end of an SI, S2, or S3 state. Note 
that the last execute cycle before the DMA cycle can be 
either a memory read, a memory write, or a non- 
memory cycle. When the CPU enters the DMA state fol- 



12 3* 




C*TA STROBE' 
IMSO ■ TPB • N) 



i 



r 



MEMORY , 

READ CYCLE " 
i 

"Oo«l'l Cjr C • oi .nttml OtUyi 
*Uifi generated 1.90a) 



) OAT£ f ROf^ MEMORY 



^EMOrtY j 
J ~ REjAD CVCLE j 




i I I 



Fig. 112 - Output instruction timing. 
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F/?. 7 73 - DMA-IN timing. 



lowing DMA-OUT, it goes into a memory read cycle. 
The memory is enabled to the bus when MRD is low 
and, after the necessary access time, valid data appears 
on the data bus and can be strobed into the output de- 
vice. An appropriate data strobe can be generated by the 
user durin g S2 when TPB is true. 

If the DMA-OUT request goes away during S2, the 
CPU will revert to a fetch cycle and complete the next 
instruction cycle. 



Interrupt Timing 

Fig. 115 provides the timing relations for interrupt 
service. INTERRUPT is a user-generated signal which 



can be asserted any time. However, the request is not 
recognized until the end of the current instruction cycle. 
It is recognized then only if the INTERRUPT ENABLE 
flip-flop in the CPU is set. Interrupt is sampled internally 
at the end of each execute cycle. The execute cycle can 
be either a memory read, a memory write, or a non- 
memory cycle. 

The interrupt state, S3, is a non-memory cycle. Dur- 
ing this period the contents of X and Pare stored in the 
temporary register T, and X and P are set to new values: 
2 in X and 1 in P. The interrupt enable flip-flop is auto- 
matically deactivated to inhibit further interrupts. The 
interrupt routine is now in control, and the next 
machine cycle is a fetch operation. 

Note: DMA has priority over Interrupt. 
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Fig. 1 14 - DMA-OUT timing. 
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Instruction Set i iming 



The timing diagram in Fig. 116 illustrates various 
timing relationships for the instruction repertoire. They 
show, for instance, whether the CPU is in a memory 
"Ircad, memory write, or non -memory cycle during the 
Jdifferent states of machine cycles. The diagrams also 
shew what the output from memory is during fetch or 
-tojxccute, or what the output from CPU to memory is. 
Srrom this point of view, the whole instruction set can 
be classified in five groups as follows: 



7 \ 



.\3roup 1. Memory cycles: 
Read/rJon-mcmory. 

Operation Code 
J IN 
2N 
31 -31 
39 -3F 
60 
76 
7A 

7B • 
7E 

| 

•roup 2. Memory cycles: 
Read/Write. 



Operation Code 
8N 
9N 
AN 
BN 
DN 
EN 
F6 
FE 



J 
J 



Operation Code 

5N 
69-6F 
73 
78 
79 



If test conditions are not met. 
!f test conditions are met. 



Operation Code 



Group 3. Memory cycles: 
Read/Read. 

Operation Code 

ON (N 0) 75 
30 77 
31-37) 7C 
39-3F/ 7D 
4N 7F 

61-67 C5-C7) 

70 CC-CFJ 

71 F0 - F5 

72 F7-FD 
74 FF 

Group 4. Memory cycles: 
Read/Read/Read. 

Operation Code 

CO 

CI -C3 i 
C9 -CB 



4> 



Group 5. Memory cycles: 
Read/Non-memory /Non-memory. 

Operation Code 

CI -C3 
C9-CB 

C4 
C5 - C7 ) 
CC-CF/ 

C8 

By way of illustration consider, for instance, the in- 
struction DECREMENT N (2N) in Group 1. During the 
instruction fetch cycle, the operation code 2N is read 
from memory and is transferred via the data bus to the 
CPU. During the next machine cycle (execute), the CPU 
generates a non-memory cycle and the memory output is 
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Fig. 116 - Instruction set timing. 
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disconnected from the bus. R(N) is decremented inter- 
nally in the CPU in the execute cycle after the I and N 
registers have decoded the instruction. 

The sequence of action is similar for a short branch 
instruction, if the test condition is not satisfied. In this 
case the program counter R(P) is simply incremented by 
1, a non-memory cycle. 

The STORE VIA N instruction (5N) is representative 
of Group 2. During the fetch cycle, the byte 5N is read 
from memory - r >d transferred over the bus to the land 
N reefers for interpretation. During the execute cycle, 
the CPU is in a memory write cycle. The memory output 
is held off the bus, and the contents of the D register are 
written into memory during the fiWR pulse at the loca- 
tion addressed by R(N). 

In Group 3, consider instruction LOAD ADVANCE 
(4N) as an example. This instruction is complementary 
t, N above. The operation code 4N is first fetched 
duung a memory read cycle. Subsequently during execu- 
tion, the byte in memory addressed by R(N) is read and 
transferred over the bus to the D register during another 
memory read cycle. R(N) is aiso incremented during 
state SI, but this operation is internal to the CPU. 

Some of the short branch instructions, for instance 
31-37 and 39-3F, belong in '.his group if the test condi- 



tions are met. In the latter case, the branch address is 
read from memory during the SI state and transferred 
over the bus to R(P).0 in the CPU. 

Group 4 may be illustrated by LONG BRANCH in- 
struction CO. As discussed previously, all C instructions 
require two machine cycles for execution. During the 
SO state the operation code is first read from memory. 
Then, the high-order branch address is read during the 
first execute cycle and loaded into R(P).l. During the 
second execute cycle, the low-order branch address is 
read and transferred over the bus to R(P).0. Hence, the 
instruction cycle represents a memory read/read/rcad 
sequence. 

Group 5 represents a memory cycle sequence of read/ 
non-memory/non-memory operations. If, for instance, 
the NO OPERATION (C4) instruction is fetched, it 
requires two machine cycles for execution which are 
both non-memory cycles. 1 

The IDLE instruction (00) represents a special case. 
After the CPU fetches the instruction from memory, il 
will "idle" in a sequence of execute states (SI) until 
DMA or Interrupt is asserted. During the idle mode, the 
memory byte addressed by R(0) is present on the data 
bus during each machine cycle. The CPU is in a memory 
read/rcad/read sequence. 
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mple Program: 



Two sample piograms are included in this section to 
illustrate the use of some of the preceding instructions 
and techniques and to demonstrate the ease with which 
they can be used to develop programs. The examples 
show programs for processing two input bytes and for 
controlling a microcomputer-driven scale. 



Processing Two input Bytes 

This program inputs two bytes from two different 
devices. These devices might be the outputs from two 
analog-to-digital converters or mechanical position re- 
solvers. The program compares the digital inputs and, if 
they are equal, sets the Q flag to '"1." In the event the 
two bytes are unequal, the flag is set to "0" and the 
larger of the two values is outputted to a third device. A 
minor change to this program could have it outputting 
the difference between the two bytes, an indication per- 
haps of the degree of mechanical "error." 

The overview operation of this program is given in the 
flow chart in Fig. 1 17. A more detailed flow chart cor- 
responding to the actual implementation is given in Fig. 
118. This flow chart more closely corresponds to the 
assembled program listing shown in Fig. I 19. 

A' few programming techniques used in this program 
warrant special attention. 

I. The INITIALIZATION block in Fig. I 17 becomes 
two blocks in Fig. I 18. A portion of the original 
initialization block is done only once during the 
execution of the program. The other part is done 
every time the program loops back to the label 
CO. This arrangement was done to save memory at 
the expense of execution time, a common trade- • 
off. The output instruction increments R(X) each 



time it is executed. To maintain R(X) pointing to 
the same memory location, it could be followed 
by a DEC R2. However, the execution of the LDI 
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Fig. 117 — Program flow chart for processing two input 
bytes: inputting two bytes, comparing them, 
outputting the larger, and setting Q to "1" if 
equal. 
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^ START ^ 



RESET Q 



M(00) : MI03I 



POINT R? TO 
STOWAGE AREA 



INPUT 1ST 
OPERAND 
IA) -r R3.0 



V.|04| . M(07) 



Mltfi) MI09) 



INPUT 2 r '0 
OPERAND 
ie) - MEMORY 



M103) : MlOEl 




MiOAl 



VES 
MIOF) : Mil 2) 

NO 





YES 




Ml 131 


SET Q 



, M|!4) : M|15l 



A IS LARGER. 
STORE INTO 
MEMORY 



OUTPUT 
THE LARGER 



MHS) : M(17| 



Ml 13) 



RESET Q 

^ Mil A) : Mi1B) 



Ml 19) 



Fig. 118 - Detailed program flow chart for processing two input bytes. 



and PLO (lines 4 and 5), which are already in the 
program, serve the same purpose. The decrement 
instruction, therefore, is purposely omiited. 

2. Lines 8 through 10 use the characteristics of the 
input instruction to advantage. Because the data 
byte goes into both memory and D, the first input 
instruction is followed by the storing of the data 
from D into a scratch-pad register. The second in- 
put instruction utilizes the feature that the data 
byte also goes into memory. After the retrieval of 
the hrsi byte from the scratch pad, the contents of 
1) and memory are ready for comparison. 

Microcomputer Scale 

This example shows a program for a price-calculating 
scale. It reads the unit price from an input device such as 
a keyboard, reads the weight of the weighed item from 
the scaJe mechanism, multiplies the numbers to produce 



the total price, and then displays the total price to the 
customer. An overall flow chart for this program is given 
in Fig. 120. This flow chart illustrates an effective ap- 
proach to the solution of moderate to large program- 
ming tasks. Each of the basic actions (initialization, in- 
put, calculation, and display) is treated as an indepen- 
dent block of code and coded as a subroutine. The final 
application program is then a collection of the subrou- 
tines flowcharted in this figure. 

The How charts for the individual subroutines arc 
shown in Figs. 121. 122, 123, and 124. In addition, tltc 
How chart of the calculation subroutine is done in suffi- 
cient detail for comparison with its assembly-language 
listing, part of which is shown in Fig. 125. The calcula- 
tion subroutine is implemented with the RCA COSMAC 
Arithmetic Subroutine Package that contains indepen- 
dent 16-bit addition, subtraction, multiplication (giving 
32 bits), division (from 32 bits), and BCD conversions to 
and from binary. Further details on this package arc 
available in Manual MPM-206. 



Applications — Sample Program's 
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0000 


7A; 


0001 


REQ 


dccct n to "n" 

, nCJC 1 KJ I \J U 


0001 


F800; 


0002 


ini a 1 f^rnnri 

LUI 1 1 J 1 i.— t • 




0003 


8?" 


0003 


PHt R2 


... 1 U r vJ 1 iN 1 Al ArntC LUUA I HJn* 


00 04 


F8 1 C: 


0004 GO: 


mi in f^Tnpfi 

L.L/1 W.U |o 1 UTit.) . 


1 M DAli U/CTOQCl 
. .. tri n AM Mlo IUMt| 


CCC6 


A2; 


0CO5 


PLO R2 




0007 


E2; 


0005 


SEX R2 




0003 


69 


0007 


IMP! 


pCAn KT IVl^ltT BVTC |MTA f~» 
. n fc A U 1 Jl 1 iN ru 1 D T 1 t 1 (H 1 U U 


0009 


A3" 


0008 


rLU nJ 


. bAVc IHh IbT |N?U 1 


OOOA 


6A 


0009 


1AJP 1 

Irir J. , 


. HtAU /NO INrU | BYTE IN IU 


0^X3 




001 




. . . M t MUM 7 




<n 

oJ , 


00 1 1 


GLOR3 


. LOAD THE 1 5T INPUT INTO 


r\rtv 


C 7- 


/Yil 


SM 


. 1ST INPUT MINUS 2ND INPUT 


ccoo 


36 18. 


rv> 1 1 

LaJ 1 J 


Due: o c c-t 
O'Nh Rfc52 


. BRANCH TO RES2 IF 2ND INPUT 




• 


00 1 4 




. . . IS GREATER THAN 1ST INPUT; 


OCDF 




00 1 S 




. . . OTHERWISE: 


000 ? 


83, 


00 1 6 


GLO R3 


. LOAD THE 1ST INPUT INTO D 


00 10 




00 1 7 


XOR 


. M{R(2)).X0R.D. TO CHECK IF THE 


001 1 




nni p 

LKJ 1 




. . . TWO INPUTS ARE EQUAL 


00 1 1 


3A 1 6; 


w i y 


nil? r* r- * 

BNZ RESl 


. BRANCH TO RESl IF NOT EQUAL 


001 3 


• ~ 


- -- . La.) i J 




. . . (1ST INPUT IS GREATER THAN 


rvi 1 1 




002 1 


• 


. . . 2ND INPUT); OTHERWISE: 


OU I J 




0022 


SEQ 


. EQUAL; SE T Q F LAG 


00 1 4 


3304, 


rvm 


SR GO 


. GO BACK TO BEGINNING 






0024 
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I 




001 6 


83 




GLO R3 , 




00 1 7 


5?" 


C026 


STR R2 . 


C~ I /*^OC IT AT til C — T 

. blUHc II AT M ( Si O n c } 


00 1 8 




0027 






0018 


61: 


0028 RES2: 


OUT 1 


. OUTPUT LARGER VALUE 


0019 


7A. 


0029 


REQ 


. RESET Q FLAG 


0O1A 


3004: 


0030 


BR GO 


. GO BACK TO BEGINNING 


00 1C 




0031 






001C 




0032 STORE: 


ORG • 


STORAGE AREA 


001C 




0033 






001C 




0034 






001C 




0035 






00 1C 




C036 






001C 




0037 


END 


EN0 OF PROGRAM SOURCE 


oooo 











Fig. 119 - Assembly listing for two-byte processing program. 



^ START ^ 



INITIALIZATION 



SUSROU 



TINE j 



READ KEYBOARD 



READ PRICE PER L8 
IN BC0 INTO 
V'PRICE" 



SUBROUTINE 



REAO WEIGHT 
IN BCD INTO 
■LSS- 



SUBR0U 



TINE \ 



CALCULATE 
TOTAL PRICE 



SUBROUTINE 



N ^OISPLAY^RESULT ^ 



Fig. 120 — Over -a! I program flov/ chart for 
microcomputer scale. 



C entry ) 



INITIALIZATION 




7 ERROR \ TELLOPERAIOH / 
- — — *\ TOREEN1FH / 



Fig. 121 — Program flow chart for keyboard subroutine. 
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READ SCALE 



^ ENTRY ^ 



INITIALIZATION 


I 




READ WEIGHT 


IN BCD 


/ 


:r 


DEL 


AY 



\ READ WEIGHT / 
IN BCD / 




122 — Program flow chart for scale subroutine. 



( EN l RY ) 



\ 



INITIAL 


ZATION 


I • 




OUTPUT NEXT 
BCD DIGIT 

V / 




( ENTRY J 



CONVERT PRICE TO BINARY 
4 



HOLD PRICE IN STACK 



CONVERT WEIGHT TO BINARY 



HOLD WE IGHT IN STACK 



I 



CALL MULTIPLY SUBROUTINE 
TAKE VALUES FROM STACK 



DIVIDE BY 100 TO REMOVE 
EXTRA DIGITS 




•CUED. 



ROUND OFF 

IZEZ 



CONVERT IOIAL PRICE 
TO DECIMAL 



T 



^ RETURN 



Fig. 124 — Subroutine flow chart for calculating total 
price. 



Fig. 123 - Program flow chart for display subroutine. 



Applications — Sample Programs 



0215 


; 


0037 




0215 


CM. 


0038 


SEP CALL. . DO OECIMAL TO BINARY CONVERSION 


0215 


076E; 


0039 


.AICD3I .." 


0213 


0270: 


0040 


,A|PHICE) . . CONVERT PRICE INTO 8INARY 


021A 


05. 


0041 


,#05 . . PRICE IS 5 CHARS LONG 


0213 




0042 


... AC NOW CONTAINS BINARY VALUE 


0213 




0043 


..OF PRICE PER POUND 


071S 




0044 




0213 


04. 


0045 


SEP CALL . . PUSH CONTENT OF AC INTO STACK 


021C 


C5£3. 


0046 


.A(PUSHAC) . . " 


021 E 




0047 




02 IE 


04. 


0043 


SEP CALL . . DO DECIMAL TO BINARY CONVERSION 


021* 


076E. 


0049 


.A(CDB) ,." 


0221 


02S2. 


00 SO 


.A(LBS) .. CONVERT QUANTITY (LBS) 


0723 




0051 


. . . INTO BINARY 


0775 


05 


0352 


.W5 . . OUANTITY IS 5 CHARS LONG 


0724 




0053 


. . AC NOW CONTAINS BINARY VALUE 


0724 




_ 0054 


'- •..OF OUANTITY (LBS) 


0724 




0055 


- 


0724 


22. 


0056 


GLOSP ..COPY STACK POINTER TO MA 


0725 


AD. 


0057 


PLO MA . " 


0725 


10 


0058 


INC MA . . POINT TO AC. 1 


072 7 


; 


0059 




C227 


04. 


0060 


SEP CALL . . DO THE MULTIPLICATION 


072B 


0475. 


0061 


.AIMPY) . . " 


022A 




0062 




072 A 




0053 


... DIVIDE BY 100 TO REMOVE LAST TWO 


022A 




0064 


. . . DECIMAL DIGITS 


022A 


12. 


0065 


INC SP . . MOVE SPTWO 8YTES 


0223 


12 


00 66 


i.NC S? ... BELOW TOP OF STACK. POP PRICE 


077C 




0057 


...OFF STACK 


C22C 


PK4. 


O06S 


LDI 100 . LOAD 100 INTO STACK WITH 


072E 


52 


0069 


STn SP ... SP POINTING TO THE HIGH BYTE 


022? 


22 


0070 


DEC SP ..." 


0230 


FB0O 


0071 


LDI 00 ..." 


0232 


52 


0072 


STR SP ..." 


0233 


62. 


0073 


GLO SP .. COPY STACK POINTER TO MA 


0234 


AO. 


0074 


PLO MA . POINT TO HIGH BYTE OF 100 


0235 


72. 


0075 


DEC SP .. POINT TO FREE SPACE 


0235 


04. 


0076 


SEP CALL 


0237 


CSIE. 


0077 


.AIDIV) . . DIVIDE PRODUCT BY 100 


0233 


334 A. 


0073 


BDF LAB 3 . . IF V E H F LOW GO TO LAB 3 


0233 




0079 




0239 




0080 


. . . CHECK IF REMAINDER IS GREATER 


0233 




0C31 


. . . THAN 50. IF SO. ROUND UP 


0233 


ZE 


0032 


GLOMQ..MQ CONTAINS THE REMAINDER 


023C 


FF32. 


0083 


SMI 50 


023E 


3841. 


0084 


BNF LABI .. IF NO ROUND UP 


0240 




0085 


... GO TO LABI 


0240 


IF. 


0C86 


INC AC .. IF ROUND UP ADO 1 TO 


0741 




0087 


...THE LEAST SIGNIFICANT DIGIT 


0241 




0C88 




024 1 


12. 


0089 LABI; 


INC SP . . MOVE SP DOWN TV/O BYTES 


0242 


12; 


0090 


INC SP ... BELOW TOP OF STACK 


0243 




0091 




0743 


04. 


0O92 


SEP CALL . . DO BINARY TO DECIMAL CONVERSION 


0244 


06-45; 


0093 


.AIC3DI .. " 


0246 


0237. 


0094 


.A(TPR) . . CONVERT TOTAL PRICE INTO DECIMAL 


0243 


06. 


0O95 


JSC6 . . TOTAL PRICE IS 6 CHARS LONG 

.. TOTAL PRICE IS STORED IN M(TPR) . 


024 9 




0098 


0243 




0097 





Fig. 125 - Partial assembly-language listing of the calculation subroutine. 



Appendix A — 
Instruction Summary 



Ths COSMAC instruction summary is given in Tables 
I and H. Hexadecimal notation is used to refer to the 
4-bit binary codes. 

In all registers bits are numbered from the least sig- 
nificant bit (LSB) to the most significant bit (MSB) 
sterling with 0. 

WWJ: Register designated by W, where W=N or X, 
orP 



R(W).0: Lower-order byte of R(W) 
R(W). 1 : Higher-order byte of R(W) 
NO = Least significant Bit of N Register 

Operation Notation 

M(R(N))-D;R(N) + I 

This notation means: The memory byte pointed lit by 
RfN) is loaded into D, and R(N) is incremented by I. 



TABLE I - INSTRUCTION SUMMARY 
by Class of Operation 



Register Operations 







OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 


INCREMENT REG N 


INC 


IN 


RfN) +1 


DECREMENT REG N 


DEC 


2N 


R(N) -1 


INCREMENT REG X 


IRX 


60 


R(X) +1 


GET LOW REG N 


GLO 


8N 


R{N).0-*D 


PUT LOW REG N 


PLO 


AN 


D-R(N).0 


GET HIGH REG N 


GHI 


9N 


R(N).1-D 


PUT HIGH REG N 


PHI 


BN 


D-Hft(N).1 


Reference 






OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 


LOAD VIA N 


LDN 


ON 


M(R(N))-D;FOR N NOT 


LOAD ADVANCE 


LDA 


4N 


M(R(N))->D;R(N) +1 


LOAD VIA X 


LDX 


F0 


M(R(X))-*D 


LOAD VIA X AND ADVANCE 


LDXA 


72 


M(R(X))-D; R(X) +1 


LOAD IMMEDIATE 


LDI 


F8 


M(R(P))-D;R(P) + 1 


STORE VIA N 


STR 


5N 


D-M(R(N)) 


STORE VIA X AND 


STXD 


73 


D-M(R(X));R(X) -1 


DECREMENT 









Logic Operations** 



INSTRUCTION 


MNEMONIC 


OP 
CODE 


OPERATION 


OR 


OR 


F1 


M(R(X)) OR D-D 


OR IMMEDIATE 


ORI 


F9 


M(R(P)) OR D-D;R(P) +1 


EXCLUSIVE OR 


XOR 


F3 


M(R(X)) XOR D-D 


EXCLUSIVE OR IMMEDIATE 


XRI 


FB 


M(R(P)) XOR D-D; R(P) +1 


AND 


AND 


F2 


M(R(X)) AND D-D 


AND IMMEDIATE 


AN I 


FA 


M(R(P)) AND D-D; R(P) +1 


SHIFT RIGHT 


SHR 


F6 


SHIFT D RIGHT. LSB(D)— DF, 








O-MSB(D) 


SHIFT RIGHT WITH 


SHRC ) 


76* 


SHIFT D RIGHT. LSB(D)— DF, 


CARRY 






DF-MSB(D) 


RING SHIFT RIGHT 


RSHR ) 






SHIFT LEFT 


SHL 


FE 


SHIFT D LEFT. MSB(D)— DF, 






7E* 


O-LSB(D) 


SHIFT LEFT WITH 


SHLC £ 


SHIFT D LEFT. MSB(D)— DF, 


CARRY 


RSHL \ 




DF-LSB(D) 


RING SHIFT LEFT 







/ 
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Arithmetic Operations** 







OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERA 1 IUN 


ADD 


ADD 


F4 


M(R(X)) +D-DF, D 


ADD IMMEDIATE 


ADI 


FC 


M(R(P) +D^DF, D; R(P) +1 


ADD WITH CARRY 


ADC 


74 


M(R(X)) +D +DF-+DF, D 


ADD WITH CARRY, 


ADCI 


7C 


M(R(P) +D +DF— DF, D 


IMMEDIATE 






R(P) +1 


SUBTRACT D 


SD 


F5 


M(R(X))-D-*DF, D 


SUBTRACT D IMMEDIATE 


SDI 


FD 


M(R(P))-D-*DF, D; R(P) +1 


SUBTRACT D WITH 


SDB 


75 


M(R(X))-D-(NOT DF)->DF;D 


BORROW 








SUBTRACT D WITH 


SDBI 


7D 


M(R(P))-D-{NOT DFJ-^DF, D; 


BORROW. IMMEDIATE 






R(P) +1 


SUBTRACT MEMORY 


SM - 


F7 


D-M(R(X))-DF, D 


SUBTRACT MEMORY 


SMI 


FF 


D-M{R(P))^DF, D; 


IMMEDIATE 






R(P) +1 


SUBTRACT MEMORY WITH 


SMB : 


77 


D-M(R(X))-(NOT DF)^DF, D 


BORROW 








SUBTRACT MEMORY WITH 


SMBI 


7F 


D-M(R(P))-(NOT DFl-DF. D 


SORROW, IMMEDIATE 






R(P) +1 


structions — Short Branch 














' 

OP 








INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 






SHORT BRANCH 


BR 


30 


M(R(P))-R(P).0 






NO SHORT BRANCH 


NBR 


38* 


R(P) +1 






(SEE SKP) 






IF D=0>!(R(P)HR(P).0 






SHORT BRANCH IF D=0 


8Z 


32 












ELSE R(P) +1 






SHORT BRANCH IF 


BNZ | 


3A 


IF D NOT 0, M(R(P))-R(P).0 






D NOT 






ELSE R(P) +1 






SHORT BRANCH IF DF = 1 


BDF \ 


33* 


IF DF = 1, M(R(P))-R(P).0 






SHORT BRANCH IF POS 


BPZ 




ELSE R(P) +1 






OR ZERO 












SHORT BRANCH IF EQUAL 


BGE 










OR GREATER 












SHORT BRANCH IF DF=0 


BNF ) 


3B* 


IF DF=0, M(R(P))-R(P).0 






SHORT BRANCH IF MINUS 


BM \ 




ELSE R(P) +1 






SHORT BRANCH IF LESS 


BL \ 










SHORT BRANCH IF Q=1 


BQ 


31 


IF CM. M(R(P)HR(P).0 












ELSE R(P) +1 






SHORT BRANCH IF Q=0 


BNQ 


39 


IF Q=0.M(R(P))-R(P).0 












ELSE R(P) +1 






SHORT BRANCH IF EF 1 = 1 


B1 


34 


IF EF1 = 1. M(R(P))-R<P)0 












ELSE R(P) +1 






SHORT BRANCH IF EF1=0 


BN1 


3C 


IF EF1=0, M(R(P))-R(P).0 












ELSE R(P) +1 






SHORT BRANCH IF EF2=1 


B2 


35 


IF EF2=1.M(R(PJ) «R(P) 












ELSE R(P) +1 






SHORT BRANCH IF EF2=0 


BN2 


3D 


IF EF2=0. M(R(P))-R(P).0 












ELSE RIP) +1 






SHORT BRANCH IF EF3=1 


B3 


36 


IF EF3=1, M(R{P))-R(P).0 












ELSE R(P) +1 






SHORT BRANCH IF EF3=0 


BN3 


3E 


IF EF3-0, M(R(P)HR(P).0 












ELSE R(P) +1 






SHORT BRANCH IF EF4=1 


B4 


37 


IF EF4=1. M(R(P))-R(P).0 












ELSE R(P) +1 






SHORT BRANCH IF EF4=0 


BN4 


3F 


IF EF4=0, M(R(P)HR(P).0 












ELSE R(P) +1 
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Branch Instructions — Long Branch 







OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 


LONG BRANCH 


LBR 


CO 


M(R(P))-*R(P).1 






C8* 


M(R(P) +1)-R(P).0 


NO LONG BRANCH 


NLBR 


RIP) +2 


(SEE LSKP) 








LONG BRANCH IF D=0 


LBZ 


C2 


IF D=0. M(R(P))->R(P).1 

M(R(P) + 1)->R(P).0 
ELSE R(P) +2 


LONG BRANCH IF D NOT 


LBNZ 


CA 


IF D NOT 0, M(R(P})-» 
R(P).1 
-M(R(P) HH 
R(P).0 
ELSE R(P) +2 


LONG BRANCH IF DF = 1 


LBDF 


C3 


IF DF = 1, M{R(P))->R(P).1 
M(R(P)+1)-> 
R(P) 
ELSE R(P) +2 


LONG BRANCH IF DF=0 


LBN'F 


CB 


IF DF=0. M(R(P))->R(P).1 
M(R(P) +!)->• 
R(P).0 
ELSE R(P) +2 


LONG BRANCH IF 0=1 


LBQ 


CI 


IF Q=1, M(R(P))->R(P).1 

M(R(P) +1)-R(P).0 
ELSE R(P) +2 


LONG BRANCH IF G=0 


LBNQ 


C9 


IF Q=0,M(R(P))-*R(P).l 
M(R«P1 +!)-»• 
R(P).0 
ELSE R(P) +2 



Skip Instructions 







OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 


SHORT SKIP 


SKP 


38* 


R(P) +1 


(SEE N8R) 




C8* 




LONG SKIP 


LSKP 


R(P) +2 


(SEE NLBR) 








LONG SKIP IF DO 


LSZ 


CE 


IF D=0, RIP) +2 
ELSE CONTINUE 


LONG SKIP IF D NOT 


LSNZ 


C6 


IF D NOT 0. R(P) +2 
ELSE CONTINUE 


LONG SKIP IF DF=1 


LSDF 


CF 


IF DF = 1, R(P) +2 
ELSE CONTINUE 


LONG SKIP IF DF=0 


LSNF 


C7 


IF DF=0, R(P) +2 
ELSE CONTINUE 


LONG SKIP IF Q=1 


LSQ 


CD 


IF 0=1. RIP) +2 
ELSE CONTINUE 


LONG SKIP IF Q=0 


LSNQ 


C5 


IF 0=0. RIP) +2 
ELSE CONTINUE 


LONG SKIP IF IE -1 


LSIE 


CC 


IF IE 1. RIP) i2 
ELSE CONTINUE 



/ 
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Control Instructions 



i 

1 
I 

,1 



1 



INSTRUCTION 


MNEMONIC 


OP 

CODE 


OPERATION 


IDLE 


mi 


nn 


WAIT FDR n'M4 DR 








liMTF R R I IPT ■ M ( R (Oil -»Rl N 


NO OPERATION 


NOP 


C4 


CONTINUE 


SET P 


SEP 


DN 


N-P 


SET X 


SEX 


EN 


N-+X 


SET Q 


SEQ 


7B 


h*a 


RESET Q 


REQ 


7A 


CH-Q 


SAVE 


SAV 


78 


T-»M(R(X)) 


PUSH X.PTO STACK 


MARK 


79 


(X.P)-T;(X,P)-M(R(2)) 






THEN P-X; R(2)-1 


RETURN 


RET 


70 


M(R(X))-(X,P); R(X) +1 








1-IE 


DISABLE 


DIS 


71 


M(R(X)MX.P};R(X) +1 








EKI6 



J 

r 
I 

I 
J 

i 



nput— Output Byte Transfer 







OP 




INSTRUCTION 


MNEMONIC 


CODE 


OPERATION 


OUTPUT 1 


OUT 1 


61 


M(R(X))->BUS; R(X) +1; 
N LINES 1 


OUTPUT 2 


OUT 2 


62 


M(R(X))-BU5;R(X) +1; 
N LINES = 2 


OUTPUT 3 


OUT 3 


63 


M(R(X))-BUS;R(X) + 1; 
N LINES = 3 


OUTPUT 4 


OUT 4 


64 


M(R{X))-*BUS;R{X) +1; 
N LINES = 4 


OUTPUT 5 


OUT 5 


65 


M(R(X))-BUS;R(X) +1; 
N LINES = 5 


OUTPUT 6 


OUT 6 


66 


M(R{X))-BUS; R{X) +1; 
N LINES = 6 


OUTPUT 7 


OUT 7 


67 


M(R(X))-BUS; R(X) +1; 
N LINES = 7 


INPUT 1 


INP 1 


69 


BUS-M(R{X));BUS->-D; 
N LINES = 1 


INPUT 2 


INP 2 


6A 


BUS-M(R(X));6US-D; 
N LINES = 2 


INPUT 3 


INP3 


6B 


BUS--M{R{X));BUS-D; 
N LINES = 3 


INPUT 4 


INP 4 


6C 


BUS-M(R(X)); BUS-D; 
N LINES = 4 


INPUT 5 


INP 5 


6D 


BUS->M(R(X));BUS-»D; 
N LINES = 5 


INPUT 6 


INP 6 


6E 


BUS-M(R{X));BUS-D; 
N LINES = 6 


INPUT 7 


INP 7 


6F 


BUS-+M(R(X));BUS-D; 
N LINES = 7 



♦ NOTE: THIS INSTRUCTION IS ASSOCIATED WITH MORE THAN ONE 
MNEMONIC. EACH MNEMONIC IS INDIVIDUALLY LISTED. 
♦ ♦NOTE: THE ARITHMETIC OPERATIONS AND THE SHIFT INSTRUCTIONS 
ARE THE ONLY INSTRUCTIONS THAT CAN ALTER THE DF. 
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TABLE II - INSTRUCTION SUMMARY 
By Numerical Order 













NUM3ER OF 


OPERATION 








MACHINE 


PROGRAM 


CODE 


OPERAND 


MNEMONIC 


NAME 


CYCLE 


BYTES 


00 




IDL 


IDLE 


2 


1 




RFT, M 
n t_ o in 


LDN 


LOAD VIA N 


2 


1 


1N 


REG N 


INC 


INCREMENT 
REG N 


2 


1 


dri 


per; m 




nFTRFMENT 
REG N 


2 


1 




MUUn coo 


R R 




2 


2 


31 


AUU n coo 


RO 


SHORT 
BRANCH 
IF Q=0 


2 


2 


32 


ADDRESS 


BZ 

i 


SHORT 
BRANCH 
IF D=0 


2 


2 


33 ) 


ADDRESS 


BDF 


SHORT 
BRANCH 
IF DF = 1 


2 


2 


I 

~ S 
i 


ADDRESS 


BPZ 


SHORT 


2 


2 






BRANCH 






i 






IF POS 






I 






OR ZERO 






ADDRESS 


BGE 


SHORT 
BRANCH 
IF EQUAL 
OR 

GREATER 


2 


2 


34 


ADDRESS 


B1 


SHORT 
BRANCH 
IF EF 1=1 


2 


2 


35 


ADDRESS 


B2 


SHORT 
BRANCH 
IF EF2=1 


2 


2 


36 


ADDRESS 


B3 


SHORT 
BRANCH 
IF EF3=1 


2 


2 


37 


ADDRESS 


B4 


SHORT 
BRANCH 
IF EF4=1 


2 


2 


»| 


ADDRESS 


N3R 


NO SHORT 
BRANCH 


2 


2 






SKP 


SHORT SKIP 


2 


1 


39 


ADDRESS 


BNQ 


SHORT 
BRANCH 
IF Q=0 


2 


2 


3A 


ADDRESS 




CLIO DT 

BRANCH 
IF D NOT 


4 


* 


3B ^ 


ADDRESS 


BNF 


SHORT 
BRANCH 
IF DF=0 


2 


2 


;i 


ADDRESS 


BM 


SHORT 
BRANCH 
IF MINUS 


2 


2 




ADDRESS 


BL 


SHORT 
BRANCH 
IF LESS 


2 


2 



I 
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INSTRUCTION SUMMARY (CONT'D) 



OPERATION 
CODE 


OPERAND 


MNEMONIC 


NAME 


mflLH 1 (M t 
LYCLto 


mi IMRFR OF 

DVTF1 
u T 1 Co 


3C 


a nn r c cc 
AUUn too 


□ IN I 


n (J n 1 


Z 


9 








DP AMfU 












lr trl -U 






on 


a nn r fcc 

AUUn coo 


OlN Z 


onU n I 




m, 


9 








DnAIMMn 












i p p p 9-n 

lr tr z-U 






or 
OE 


a nn r p 
AUUnc 00 




onU n l 




9 








RRAWPW 
DnMINOn 












I r tr 0— U 






or 


a nn n f cc 
a\ U U n i_ 00 


DIN *4 


cunpT 
MU n 1 




£. 


9 








R PJ A MPU 












i p p p/i-n 

lr P r 'V — U 










i n a 

L JM 


LUMU 



a 


1 
1 








ML/ Vn!vL/C 






rm 


R F C M 


P 

i n f 


CTH DC \ / I A M 
O I U 1 1 C V In 11 


9 


1 


Rn 




J n A 


IMP DC M C M T 


9 


1 
1 








n c u a 






D 1 


ncwirF 1 




Dl JTPI IT1 


9 


1 


R? 


nc\/;,~c 9 


HI )T9 


Ol IT PI IT? 


9 






1 • — V ' Vj i — 


OUT? 


Ol JTPI IT? 


9 
c 


1 


Rd 


W C V 1 C_ *^ 


O! IT4 

W \J 1 *"f 


Ol fTPt IT4 

W U 1 I U 1 4 


9 

A 


1 


DJ 


n F V 1 C F R 


Dl ITS 


Ol fTPl ITR 


2 


, 


RR 


ncvif'F fi 

L V IVjt L) 


ni itm 

'JU 1 u 


Ol ITPl ITfi 


2 




R7 


DEVICE 7 


1 IT 7 


Dl ITPl )T7 

U U 1 1 u 1 / 


2 


1 


RQ 


rj c v / 1 p c 1 

UL V i^C 1 


I MP 1 
Mir 1 


1 1 


9 


1 


Oh 


L<L V IL-L Z 


1 MP9 


| Mpi IT? 
1 IN. r f Z 


9 


1 
1 


RFt 
DO 


np \/ 1 r p ^ 


'MPT 

iHr J 


1 IN r L/ 1 *5 


9 


1 
1 


RP 


np\/irP a 


! MP/1 
1 14 1 H 


f M PI ITd 
i IN r U 1 H 


tC 


1 
1 


DU 


UtvlLC D 


! M P£ 
1 iN r D 


1 M pi IT CI 
1 IN r U 1 D 


9 


1 
1 


RC 
DC 


Uc V o 




iMDi |TC 

il\rU 1 D 




z 


1 


RC 

or 


Utv lot / 


IMP7 
i N r / 


IMpt IT 7 


z 


1 


"?n 
/U 




n t 1 


pCTi j D M 

n c 1 U n v4 


z 


1 


/ 1 




w 1 


nic AD 1 p 


9 
z 


1 
1 


75 




1— L/ /\ AA 


1 DAD VIA X 


2 


•J 








ML/ Vnlil/L 






7T 
/ o 






QTHRP VIA y 


9 


1 








AN D 












npr RFMFNT 

L/ 1 V_f til 1 • 1 l_ 1 M 1 






74 




ADC 


ADD WITH 


2 


1 








CARRY 






75 




SOB 


SUBTRACT 


2 


1 








D WITH 












BORROW 






7R > 
I 




on n 


CWl FT R 1 r,HT 


9 


1 








WITH 
vv 1 1 n 






? 
1 






PA r a Y 
la n n 1 










DCUp 

nOfln 


DlMr CWI FT 


9 


1 

1 








n 1 vo n 1 






/ / 




OlYlD 


CI IDTD A fT 

OUD 1 nrtLI 


9 


1 








MEMORY 












WITH 












BORROW 






78 




SAV 


SAVE 


2 


1 


79 




MARK 


PUSH X.P 


2 


1 








TO STACK 






7A 




SEQ 


SET Q 


2 


1 


7B 




REQ 


RESET Q 


2" 


1 


7C 


DATA 


ADDI 


ADD WITH 


2 


2 








CARRY 












IMMEDIATE 
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INSTRUCTION SUMMARY (CONT'D) 













NUMBER OF 


OPERATION 








MACHINE 


n o r~\ D A A A 
PRUU HAH 


CODE 


OPERAND 


MNEMONIC 


NAME 


CYCLES 


BYTES 


7D 


DATA 


SDBI 


SUBTRACT 
D WITH 
BORROW 
IMMEDIATE 


2 


2 


7E 




SHLC 


SHIFT LEFT 
WITH CARRY 


2 


• 
1 






ribHL 


n I r \ o o M 1 r 1 

LEFT 


z 


1 


7F 


DATA 


CI in i 


bUb 1 HAL 1 

MEMORY 

IA/ ITU DHO 

Wl 1 H dUH- 
ROW. 

1 M M t L) 1 A 1 t 


z 


o 


8N 


RcG N 


GLO 


Lib I LUW ntlj 

N 


z 




9N 


REG N 


GH 1 


/ — r HT | 1 1 r" I 1 

Gc 1 HIGH 
REG N 


Z 




AN 


REG N 


PLO 


m it" t rwrtt 
PL) ! LUW 

REG N 


Z 




BN 


REG N 


PHI 


PU 1 HIGH 
rtfcu fS1 


Z 




CO 


ADDRESS 


LBR 


LONG BRANCH 


3 


3 


C1 


ADDRtSb 


LBQ 


LUlNu tinArJUH 

IF 0=1 


J 


o 


C2 


ADDRESS 


LB<i 


i r"\ m dd a Mru 
LUN'o BhANGH 

IF D=0 


J 


o 
O 


CJ 


ADD He 3b 


I one 


t c\\\c noAMru 

LvJINu DnAlNLn 

IF DF=1 


o 
o 


o 


C4 


- 


NOP 


NO OPERATION 


3 


1 


rc 




LSNQ 


I ONG SKIP IF 
Q=0 


3 




CF, 




LSNZ 


LONG SKIP IF 
D NOT 


3 




n 
/ 


• 


LSNF 


LONG SKIP IF 
DF=0 


3 




C8 1 




LSKP 


LONG SKIP 


3 






ADDRESS 


NLBR 


NO LONG 
BRANCH 


3 


3 


C9 


ADDRESS 


LBNQ 


LONG BRANCH 
IF Q=0 


3 


3 


CA 


ADDRESS 


LBNZ 


LONG BRANCH 
IF D NOT 


3 


3 


CB 


ADDRESS 


LBNF 


LONG BRANCH 
IF DF=0 


3 


3 


CC 


— 


LSlE 


LONG SKIP 
IF IE=1 


3 


1 


CD 


— 


LSQ 


LONG SKIP 
IF Q=1 


3 


i 
1 


CE 




L.SZ 


LONG SKIP 
IF D=0 


3 


1 


CF 




LSDF 


LONG SKIP 
IF DF = 1 


3 


1 


DN 


REG N 


SEP 


SET P 


2 


1 


EN 


REG N 


SEX 


SET X 


2 


1 


F0 




LDX 


LOAD VIA X 


2 


1 


F1 




OR 


OR 


2 


1 


F2 




AND 


AND 


2 


1 



I 
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INSTRUCTION SUMMARY (CONT'D) 













M I f \ 4 R F R OF 


OPERATION 








MACHINE 


PROGRAM 


CODE 


UrtHANU 






("VP t C Q 
LYOLto 


L> * ICO 


F3 






L AVjLUJI V I— 

OR 




1 


F4 


- 


ADD 


ADD 


2 


1 


ft; 






91 IRTRAPT Pi 




1 

1 


F6 


- 


SHR 


SHIFT RIGHT 


2 


1 


F7 




SM 


91 IRT R ATT 

MEMORY 


? 


1 


F8 


DATA 


i ni 


1 DAD 

l . \J AA LJ 

IMMFniATF 




2 


F9 


DATA 


ORI 


OR 

IMMEDIATE 


2 


2 


FA 


DATA 


ANI 


AND 

IMMEDIATE 


2 


2 


FB 


DATA 


XRI 


EXCLUSIVE 
OR 

IMMEDIATE 


2 


2 


FC 


DATA 


ADI 


ADD 
IMMEDIATE 


2 


2 


FQ 


DATA 


SDI 


SUBTRACT D 
IMMEDIATE 


2 


2 


FE 




SHL 


SHIFT LEFT 


2 


1 


FF 


DATA 


SMI 


SUBTRACT 
MEMORY 
IMMEDIATE 


2 


2 



Interpretation of DF 



Hexadecimal Code 





DF 


Carry 

Generated 


Borrow 
Generated 


D 


After 
Addition 


1 


Yes 









No 


After 

Subtraction 


1 




No 


Positive Number 







Yes 


Negative Number 
2's complement 



HEX 


BINARY 





0000 


1 


0001 


2 


0010 


3 


001 1 


4 


0100 


5 


0101 


6 


0110 


7 


0111 



HEX 


BINARY 


8 


1000 


9 


1001 


A 


1010 


B 


1011 


C 


1 100 


D 


1101 


E 


1110 


F 


1111 



COSMAC Register Summary 



D 


8 Bits 


Data Register 
(Accumulator) 


DF 


1 Bit 


Data Flag (ALU Carry) 


R 


16 Bits 


1 of 1 6 Scratchpad 
Registers 


P 


4 Bits 


Designates which register 
is Program Counter 


X 


4 Bits 


Designates which register 
is Data Pointer 



N 


4 Bits 


Holds Low-Order Instr. 
Digit 


I 


4 Bits 


Holds High-Orderlnstr. 
Digit 


T 


8 Bits 


Holds old X. P after 
1 nterrupt (X is high 
byte) 




1 Bit 


Interrupt Enable Flip Flop 


Q 


1 Bit 


Output Flip Flop 
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Appendix B — 
State Sequencing 



tOT? C 



FETCH 



S2 

DMA I'i.OL'T 
CYCLE 



DMA 



DMA 



CYCLE 

121 

SI 

EXECUTE 
CYCLE 



DMA 



DMA IN T 



51 



S3 

INTERRUPT 
CYCLE 



A 



:DlT DMA ■ INT 



INT DMA 



- State Type 


State Code Lines 


SC1 


SCO 


SO (Fetch) 


L 


L 


S1 (Execute) 


L 


H 


S2 (DMA) 


H 


L 


S3 (Interrupt) 


H 


H 



The CD?! 802 state transitions when in the RUN mode. 
Each cycle requires the same period of time— 8 clock 
puhes. The execution of an instruction requires either 



two or three machine cycles, SO followed by a single SI 
cycle or by two SI cycles. S2 is the response to a DMA 
request and S3 is the interrupt response. 



RESET - RUN MODE 



j CLEAR - 

\ waTt » l 



RESET 
' MODE " 



CLEAR 



STATE 


SI 


SI 


SI 


SI 


■ SO" 


SI 


SO 


SI 




STATE CODE 
SCI. SCO 


LH 


LH - 




LH 


LH 


LL 


LH 


LL 


LH 










INTERRUPTS 






INSTRUCTION 










DISABLED 








TIME 







111 Instruction Fetch from MI0OOOI 



*S2. il DMA AH alerted, but ne»er S3 



SOME HAVE TWO 
SI STATES 



RUN - PAUSE - RUN MODE: 



RUN - 



WAIT -0 
\ 



-PAUSE - 



WAIT - 1 

A, . 



MACHINE 
CYCLES 


n 




; ■ n,J 


n-3 




STATE 






SO. SI.S2«S3 







DMA AND INTERRUPT MOOE. 



DMA IN 



INTERRUPT 



DMA OUT 



STATE 




SO 


SI 


SO 


SI 


S2 


SO 


SI 


S3 


SO 


SI 


SO 


SI 


S2 


SO 


SI 




STATE CCOE 

sci. sco 




LL 


LH 


LL 


LH 


HL 


LI. 


LH 


HH 


LL 


LH 


LL 


LH 


HL 


LL 


LH 
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Appendix C — 
Terminal Assignments for the 
RCA CDP1302 COSMAC Microprocessor 



SIGNAL NAME 
> CLOCK 



CONTROL 

s» 



STATE 
CODES 
■o — — - 



fv/AIT 
\cLEAi 

{ 



DATA . 
BUS 
< > 



170 _ 
COMMANDS 



CLEAR 
Q 

SCI 
SCO 
MRD 
BUS 7 
BUS 6 
BUS 5 
BUS 4 
BUS 3 
BUS 2 

eus i 

BUS 

v cc 

N2 
N I 
NO 
V SS 







. 40 






2 


39 






3 


30 






4 


37 






5 


35 






6 


35 






7 


34 






8 


33 






9 


32 






10 


31 






1 1 


30 






12 


29 






13 


28 






14 


27 






1 5 


25 






16 


25 






17 


24 






1 8 


23 






19 


22 






20 


21 





TOP VIEW 





SIGNAL HX'-tZ 

V D0 
XTAL 
DMA IN 



DMA OUT 
INTERRUPT 

y 

MWR 
TPA ~] 
TPB J 
MA 7 
MA 6 
MA 5 
MA 4 
MA 3 
MA 2 
MA I 
MA 

rrr 

EF 2 
EF 3 
EF4 



I/O 

REQUESTS 



TIMING 

PULSES 
> 



MEMORY 
ADDRESS 
»• 



I/O 
FLAGS 



S2CS-27-4S7 
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Appendix D 
COSMAC Dictionary 



Accra Time: Time between the instant that an address is 
sen! to a memory and the instant that data returns. Since 
the access time to different locations (addresses) of the 
memory may be different, the access time specified in 
a memory device is the path which takes the longest time. 

Accumulator: Reg5ii.fl and related circuitry which holds one 
operand for arithmetic and logical operations. 

Additional Hardware: Microprocessor chips differ in number 
of additional ICs required to implement a functioning 
computer. Generally, timing, I/O control, buffering, and 
interrupt control require external components. 

Address: A number used by the CPU to specify 2 location 
in memory. 

Addressing Modes: See Memory Addressing Modes 

ALU: Arithmetic-Logic Unit. That pa't of a CPU which 
executes adds, subtracts, shifts, AND**, OR's, etc. 

Architecture: Organisational structure of a computing 
syilcm, mainly referring to the CPU or microprocessor. 

Assembler: Software that converts .an assembly-language 
program into machine language. The assembler assigns 
locations in storage to successive instructions and re- 
places symbolic addresses by machine language equiva- 
lents. If the assembler runs on 3 computer other than 
that for which it creates the machine language, it is a 
Cross- Assembler. 

Assembly Language: An English-like programming language 
which saves the programmer the trouble of remembering 
the bit patterns in each instruction; also relieves him of 
the necessity to keep track of locations of data and in- 
structions in his program. 

The assembler operates on a "one-for-one" basis in that 
each phrase of the language translates directly into a 
specific machine-language word, as contrasted with High 
Level Language. 

Assembly Listing: A printed listing made by the assembler 
to document an assembly. It shows, line for line, how the 
assembler interpreted the assembly language program. 

Asynchronous Operation: Circuit operation without reliance 
upon a common timing source. Each circuit_j?peration is 
terminated (and next operation initiated) by a return 
signal from the destination denoting completion of an 
operation. (Contrast with Synchronous Operation). 

Baud: A communications measure of serial data transmission 
rate; loosely, bits per second but includes character- 
framing START and STOP bits. 



Benchmark Program: A sample program used to evaluate 
and compare computers. In general, two computers will 
not use the same number of instructions, memory words, 
or cycles to solve the same problem. 

Bit: An abbreviation of "binary digit". (Single characters in 
a binary number.) 

Bootstrap (Bootstrap Loader): Technique or device for 
loading first instructions (usually only a few words) of a 
routine into memory; then using these instructions to 
bring in the rest of the routine. 

The bootstrap loader is usually entered manually or by 
pressing a special console key. COSMAC does not need 
one. See Load Facility. 

Branch: See Jump. 

Branch Instruction: A decision-makir.g instruction which, 
on appropriate condition, forces a new address into the 
program counter. The conditions may be zero result, 
overflow on add, an external flag raised, etc. One of two 
alternate program segments in the memory are chosen, 
depending on the results obtained. 

Breakpoint: A location specified by the user at which 
program execution (real or simulated) is to terminate. 
Used to aid in locating program errors. 

Bus: A group of wires which allow memory, CPU. and I/O 
devices to exchange words. 

Byte: A sequence of n bits operated upon as a unit is called 
an n-bit byte. The most frequent byte size is 8 bits. 

Call Routine: See Subroutine 

Clock: A device that sends out timing pulses to synchronize 
the actions of the computer. 

Compiler: Software to convert a program in a high-level 
language such as FORTAN into an assembly language or 
machine language program. 

COSMAC: Generic description for the RCA family of 
compatible microprocessor products { 1 800 scries). Based 
on a unique architecture, the COSMAC family includes 
CPU's, memories. I/O's, prototyping systems, and soli- 
ware. 

COSMAC Development System (formerly "Microkit"): 
Microcomputer used for software development and sys- 
tem prototyping. Uses the COSMAC I800 family of 
microprocessor products. 

COSMAC Software Development Package (CSDP): An 
assembler and interactive debugger simulator for COS- 
MAC microcomputer systems. The debugger is a power- 
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ful "software oscilloscope" that allows the user to start 
and stop the simulator, examine and modify the program 
variables, and dump and restore the entire simulated 
machine at will. CSDP is available either on the General 
Electric Mark III Service or as a Fortran IV program that 
can be easily installed cn a host computer. 
Cross Assembler: A symbolic language translator that runs 
on or.e type of computer to produce machine code for 
another type of computer. See Assembler. 

CPU (Central Processing Unit) Th3t part of a computer 
system (hat controls the interpretation and execution of 
instructions. In general, the CPU contains the following 
elements: 

Arithmetic-Logic Unit (ALU) 

Timing and Control 

Accumulator 

Scratch-pad memory 

Program counter and address stack 

Instruction register and decode 

Parallel data and I/O bus 

Memory and I/O control 

Cycic Stealing: A memory cycle stolen from the normal CPU 
operation for a DMA operation. See DMA. 

Cycle Time: Time interval at which any set of operations is 
repeated regularly in the same sequence. 

D Register: The accumulator in the COSMAC micro- 
processor. 

Data Pointer: A register holding the memory address of the 
data (operand) to be used by an instruction. Thus the 
register "points" to the memory location of the data. 

Data Register: Any register which holds data. In the 
COSMAC microprocessor, any one of the Id x 1 6 
scratch pad rcgisiers can be used to hold two bytes of 
data. 

Debug. To eliminate programming mistakes, including 
omissions, from .1 program. 

Debug Programs: Debug programs help the programmer to 
find errors in his programs while they are running on the 
computer, and allow him to replace or patch instructions 
into (or ou! of) his program. 

Designator: The :hrce 4-bi! registers P. X. and N in the 
COSMAC microprocessor are called designators. P and 
X arc used Id designate which one of the sixteen Id-hit 
scratch pad rcgisteis is died as the current program 
counter and the data pointer, respectively. 

N can designate: one of the scratch-pad registers; an I/O 
device or command; a new value in P or X; and a 
further definition of an instruction. 

Diagnostic programs: These programs check the various 
hardware parts of a system for proper operation; CPU 
diagnostics check the CPU. memory diagnostics check 
the memory, and so forth. 

Direct Addressing: The address of an instruction or operand 
is completely specified in an instruction without reference 
to a base register or index register. 



DMA: Direct Memory Access. A mechanism which allows an 
input/output device to take control of the CPU for one 
or more memory cycles, in order to write to or 'read 
from memory. The order of executing the program steps 
(instructions) remains unchanged. 

Editor: As an aid in preparing source programs, certain 
programs have been developed that manipulate text 
material. These programs, called editors, text editors, or 
paper tape editors make it possible to compose assembly 
language programs on-line, or on a stand-alone system. 

Execute: The process of interpreting an instruction and 
performing the indicated operation(s). 

Fetch: A process of addressing the memory and reading 
into the CPU the information word, or byte, stored at 
the addressed location. Most often, fetch refers to the 
reading out of an instruction from the memory. 

Firmware: Software which is implemented in ROM's. 

Fixed-instruction Computer (Stored-Instruction Computer): 
The instruction set of a computer is fixed by the 
manufacturer. The users will design application programs 
using this instruction set (in contrast to the Micro- 
programmable Computer for which the users must design 
their cwn instruction set and thus customize the com- 
puter for their needs.) 

Fixed Memory: See ROM 

Flag Lines: Inputs to a microprocessor controlled by I/O 
devices and tested by branch instructions. 

Fortran: A high-level programming language generally for 
scientific use, expressed in algebraic notation. Short for 
"Formula Translator". 

Guard: A mechanism to terminate program execution (real 
or simulated) upon access to data at a specified memory 
location. Used in debugging. 

Hardware: Physical equipment forming a computer system. 

Hexadecimal: Number system using 0, 1 , A, B, C, 

D. E, F to represent all the possible values of a 4-bit 
digit. The decimal equivalent is to 15. Two hexa- 
decimal digits C3n be used to specify a byte. 

High-Leve! Language: Programming language which gener- 
ates machine codes from problem- or function-oriented 
statements. FORTRAN. COBOL, and BASIC arc three 
commonly used high-level languages. A single functional 
statement may translate into a series of instructions or 
subroutines in machine language, in contrast to a low- 
level (assembly) language in which statements translate 
on a one-for-one basis. 

Immediate Addressing: The method of addressing an 
instruction in which the operand is located in the 
instruction itself or in the memory location immediately 
following the instruction. 

Immediate Data: Data which immediately follows an 
instruction in memory, and is used as an operand by 
that instruction. 

Indexed Addressing: An addressing mode, in which the 
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the address part oT an instruction is modified by the 
contents in an auxiliary (index) register during the 
execution of that instruction. 

Index Register: A register which contains a quantity which 
may be used to modify memory address. 

Indirect Addressing: A means of addressing in which the 
address of the operand is specified by an auxiliary register 
or memory location specified by the instruction rather 
than by bits in the instruction itself. 

Input-Output (I/O): General term for the equipment used to 
communicate with a computer CPU; or the data involved 
in that communication. 

Instruction: A set of bits that defines a computer operation, 
and is a basic command understood by the CPU. It may 
move. dat3, do arithmetic and logic functions, control 
I/O devices, or make decisions as to which instruction to 
execute next. 

Instruction Cycle: The process of fetching an instruction 
from memory and executing it. 

Instruction Length: The number of words needed to store 
an instruction. It is one word in most computers, bu! 
some mil use multiple words to form one instruction. 
Multiple word instructions have different instruction 
execution times depending on the length of the instruction. 

Instruction Repertoire: Sec Instruction Se: 

Instruction Set: The set of general-purpose instructions 
available with j given computer In general, different 
machines have different instruction sets. 

The number of instructions only partially indicates the 
quality of an instruction set. Some instructions may 
only be slightly different from one another; others 
rarely may he used. Instruction sets should be compared 
using benchmark programs tvpiLjl of the application. to 
determine execution times, and memory requirements. 

Instruction Time: The time required to fetch an instruction 
from memory and then execute it. 

interpreter: A program which letches and executes "in 
>lruclions" (pseudo instructions) written in a higher 
level language. The higher level language program is a 
ps^udo program. Contrast with Compiler. 

Interrupt Request: A signal to the computer thai tempo- 
rarily suspends lite normal sequence of a routine and 
transfers control to a special routine Operation can be 
resumed from this point laier. Ability to handle inter- 
rupts is vciy useful in communication applications where 
It allows the microprocessor lo \civkc many channels 

Interrupt Mask (Interrupt Enable) A mechanism which 
allows the program to specify whether or not interrupt 
requests will be accepted. 

Interrupt Service Routine: A routine (program) to properly 
store awa> to the stack the present status of the machine 
in order to respond to an interrupt request ; perform the 

i 



"real work" required by the interrupt; restore the saved 
status of the machine; and then resume the operation of 
the interrupted program. 

I/O Control Electronics (I/O Controller): The control 
electronics required to interface an I/O device to a 
- computer CPU. 

The powerfulncss and usefulness of a CPU is very closely 
associated with the range of I/O devices which can be 
connected to it. One can not usually simply plug them 
into the CPU. The I/O Control Electronics will do the 
"matchmaking". The complexity and cost of the Control 
Electronics are very much determined by both the hard- 
ware and software I/O architecture of the CPU. 

I/O interface: See I/O Control Electronics 

I/O Port: A connection to a CPU which is configured (or 
programmed) to provide a data path between the CPU 
' and the external devices, such as keyboard, display, 
reader, etc. An I/O port of a microprocessor may bean 
input por! or an output porl , or it may be bidirectional. 

Jump: A departure from the normal one-step incrementing 
of the program counter. By forcing a new value (address) 
into the program counter the next instruction can he 
fetched from an arbitrary location (cither further ahead 
or back). 

Eor example, a program jump can be used to go from 
the main program to a subroutine, from a subroutine 
back to the main program, or from the end of a short 
routine back to the beginning of the same routine to 
form a loop. See also the Branch Instruction. If you 
reached this point from Branch, you have executed a 
Jump. Now Return. 

Linkage: See Subroutine 

Load Facility: A hardware facility to allow program loading 
using DMA. It makes bootstrap unnecessary. 

Loader: A program to read a program from an input device 
into RAM. May be pari of a package ol utility programs. 

Loop: A self-contained series of instructions in which the 
last instruction can cause repetition of [he series until a 
terminal condition is reached. Branch instructions are 
used to test the conditions in the loop lo determine if 
ihe loop should he continued or terminated. 

Low-Level Language: See Assembly Language 

Machine: A term for a computer (of historical origin). 

Machine Code: See Machine Language 

Machine Cycle: The basic CPU cycle. In one machine cycle 
an address may be sent lo memory and one word (data 
or instruction) read or written, or. in one machine cycle 
a fetched instruction can be executed. One machine 
cycle in the COSMAC microprocessor consists of eight 
clock pulses. 

Machine Language: The numeric form of specifying in- 
structions, ready for loading into memory and execution 
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by the machine. This is the lowest-level language in 
which to write programs. The value of every bit in every 
instruction in the program must be specified (e.g., by 
giving a string of binary, octal, or hexadecimal digits for 
the contents of each word in memory). 

Machine State: See State Code 

Macro (Macroinstruction): A symbolic source language 
statement which is expanded by the assembler into one 
or more machine language instructions, relieving the 
programmer of having to write out frequently occuring 
instruction sequences. 

Manufacturer's Support: It includes application information, 
software assistance, components for prototyping, availa- 
bility of hardware in all configurations from chips to 
systems, and fast response to requests for engineering 
assistance. - - "* 

Memory: Thai part of a computer which holds dat3 and 
instructions. Each instructions or datum is assigned a 
unique address which is used by the CPU when fetching 
or storing the information. 

Memory Address Register: The CPU register which holds 
the address of the memory location being accessed. 

Memory Addressing Modes: The method of specifying 
(he memory location of an operand. Common addressing 
modes are direct, immediate, relative, indexed, and 
indirect. These mode', jrc important fjctors in ptogrjni 
efficiency. 

Microcomputer: A compulcr whose CPU is a micro- 
processor. A microcomputer is jn entire system with 
microprocessor, memory, and input-output controllers. 

Microprocessor: Frequently called "a computer on a chip". 
The microprocessor is. in reality, a set of one. or a lew. 
LSI circuits capable of performing t lie essential functions 
of a compulcr CPU 

Microprogrammable Computer: A computer in which ihc 
internal CPU control sigiul sequence for performing 
instructions arc generated from j ROM. By chunking the 
ROM contents, the instruction sei can be changed. This 
contrasts with a lixed-liislruclion Compulcr in which 
the instruction set can not he readily changed. 

Microtutor: Inexpensive microcomputer foi first -level hands- 
on experience with microprocessor hardware and pro- 
gramming. Comes complete wnh CPU. memory, inpul 
and out put devices, and power supply. 

Mnemonics: Symbolic names or abbreviations for instruc- 
tions, registers, memory locations, etc. A technique for 
improving the efficiency of the human memory. 

Multiple Processing: Configuring two or more processors in 
a single system, operating out of a common memory. 
This arrangement pennus execution of as many pro- 
grams as there are processors. 

Nesting. Subroutines which are called by subroutines are 
said to be nested. The nesting level is the number of 
times nesting can be repeated. 



Nibble: A sequence of 4 bits operated upon as a unit. Also 
see Byte. 

Object Program: Program which is the output of an auto- 
matic coding system, such as the assembler. Often the 
object program is a machine-language program ready for 
execution. 

On-Line System: A system of I/O devices in which the 
operation of such devices is under the control of the 
CPU, and in which information reflecting current ac- 
tivity is introduced into the data processing or con- 
trolling system as soon as it occurs. 

Op Code (Operation Code): A code that represents specific 
operations of an instruction. 

Operating System: System software controlling the overall 
operation of a multi-purpose computer system, including 
such tasks as memory allocation, input and output distri- 
bution, interrupt processing, and job scheduling. 

Page: A natural grouping of memory locations by higher- 
order address bits. In an 8-bit microprocessor, 2^ = 256 
consecutive bytes often may constitute a page. Then 
words on the same page only differ in the lower-order 
8 address bits. 

PLA (Programmable Logic Array): A PLA is an array of 
logic elements which can be programmed to perform a 
specific logic function. In this sense, the array of logic- 
elements can be as simple as a gate or as complex as a 
ROM. The array can be programmed (normally mask, 
programmable) so that a given input combination 
produces a known output function. 

Pointer: Regisiers in the CPU which contain memory 
addresses. See Program Counter and Data Pointer. 

Program: A collection of instructions properly ordered to 
perforin some particular task. 

Program Counter: A CPU register which specifics the 
address of the next instruction to be fetched and 
executed. Normally it is incremented automatically each 
time an instruction is fetched. 

PROM (Programmable Read-Only Memory): An inlcgiatcd- 
circuit memory array that is manufactured with a pattern 
of either all logical zeros or ones and has a specific pattern 
written into it by the user by a special hardware pro- 
grammer. Some PROMs, called EAROMs, Electrically 
Alterable Read-Only Memory, can be erased and rcpro- 
grammed. 

Prototyping System: A hardware system used to breadboard 
a microprocessor-based product. Contains CPU, memory, 
basic I/O. power supply, switches and lamps, provisions 
for custom I/O controllers, memory expansion, and 
often, a utility program in fixed memory (ROM). See 
COSMAC Development System. 

Psciido Instruction: Sec Interpreter 

Pseudo Program: See Interpreter 

RAM (Random Access Memory): Any type of memory 
which has both read and write capability. It is randomly 
accessible in the sense that the time required to read 
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from or to write into the memory, is independent of the 
location of the memory where data was most recently 
read from or .v^'ten into. In contrast , in a Serial Access 
Memory, this time is variable. 

Register: A fast-access circuit used to store bits or words in 
a CPU. Registers play a key role in CPU operations. In 
most applications, the efficiency of programs is related 
to the number of registers. 

RelaiWe Addressing: The address of the data referred to is 
the address given in the instruction plus some other 
number. The "other number" car, be the address of the 
instruction, the address of the first location of the cur- 
rent memory page, or a number stored in a register. 
Relative addressing permits the machine to relocate a 
program or a block of data by changing only one number. 

Resident Software: Assembler and editor programs incor- 
porated with a prototyping system to aid in user program 
writing and development See Software. 

Return Routine: See Subroutine 

ROM: Read-Only Memory (Fixed Memory) is any type of 
memory which, cannot be reai-iy re*ritien; ROM 
requires a masking operation dunnj production to per- 
manency record program cr dc'.a patterns in it. The 
information is stored on a perrsiiem basis and used 
repetitively. Such storage is useful for programs or tables 
of data that remain fixed and is usually randomly 
accessible. 

Routine: Usually refers to a sub program, i.e.. the task per- 
formed by the routine is less complex. A program may 
include routines. See Program. 

Scratch-Pad Memory: RAM or registers which are used to 
store temporary intermediate res j I :s (data), or memory 
addresses (pointers) 

Serial Memory (Serial Access Memory) Any type of 
memory in which the time required to read from or 
write into the memory is dependent on the locution in 
the memory. This type of memory has to wail while 
nondesired memory locations are accessed. Examples 
are paper tape. disc, magnetic tape. CCD. etc In a 
Random Access Memory, access time is constant. 

Simulators: Software simulators jre sometimes used in the 
debug process to simulate the execution of machine- 
language programs using another computer (ofien a 
timesharing system). These simulators arc especially 
useful if the actual compute i is ni l available. They may 
facilitate the debugging by providing access lo internal 
register of the CPU wllicll are mil brouglll oul lo 
(Menu) puis in I Ik hanlwaie Sec COSMAC Software 
Development Package. 

Snapshots: t'apliiie of itw CllttlC Mate Hi a machine 
(ical i'i simulated) memory contents. icgisieis. 

flap., etc. 

Software: Computer programs. Olien used to denote 
general purpose programs provided by the manufacture/, 
such as assembler, editor, compiler, etc. 



Source Program: Computer program written in a language 
designed for ease of expression of a class of problems or 
procedures, by humans: symbolic or algebraic. 

Stack: A sequence of registers and/or memory locations 
used in LIFO fashion (last-in-first-out). A stack pointer 
specifies the last-in entry (or where the next-in entry 
will go). 

Stack Pointer: The counter, or register, used to address a 
stack in the memory. See Stack. 

Stand-Alone System: A microcomputer software develop- 
ment system which runs on a microcomputer without 
connection to another computer or a timesharing system. 

■ This system includes an assembler, editor, 3nd debugging 
aids. It may include some of the features of a prototyping 
kit. 

■ 

State Code: A coded indication of what state the CPU is 
— responding to an interrupt, servicing a DMA request, 
executing an I/O instruction, etc. 

Subroutine: A subprogram (group of instructions) reached 
from more than one place in a main program. The process 
of passing control from the main program to a sub- 
routine is a subroutine call, and the mechanism is a 
subroutine linkage. Often data or data addresses arc 
made available by the main program to the subroutine. 
The process of returning control from subroutine to 
main program is subroutine return. The linkage auto- 
matically returns control to the original position in the 
main program or to another subroutine. See Nesting. 

Subroutine Linkage: See Subroutine 

Support: See Manufacturer's Support 

Synchronous Operation: Use of a common timing source 
(clock) lo time circuit or data transfer operations. 
(Contrast with Asynchronous operation) 

Syntax: Formal structure. The rules governing sentence 
structure in a language, or statement structure in a 
language such as assembly language or Fortran. 

Terminal: An Input-Output device at which data leaves or 
enters a computer system, e.g.. teletype terminal, CRT 
terminal, etc. 

Test and Branch: See Branch Instruction 

Unbundling: Pricing certain types of software and services 
separately from the hardware. 

Universal Asynchronous Receiver/Transmitter (UART): A 
device thai translates serial data hits from two-wire lines 
to paiallel formal (receive mode) or parallel data bits to 
serial formal for transmission over Iwu-wiie lines (trans- 
mil mode). 

Utility Program: A program providing basic conveniences, 
such as capability foi loading and saving programs, lor 
observing and changing values in a Computer, and for 
initialing program execution. The utility program elimi- 
nates the need for "re-inventing the wheel" every time a 
designer wants to perform a common function. 

Word: The basic group of bits which is manipulated (read 
in, stored, added, read out, etc.) by the computer in a 
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single step. Two types of word are used in every 
computer: Data Words and Instruction Words. Data 
words contain the information to be manipulated. 
Instruction words cause the computer to execute a 
particular operation. 



Word Length: The number of bits in the computer word. 
The longer the word length, the greater the precision 
(number of significant digits). In general, the longer the 
word length, the richer the instruction set, and the more 
varied the addressing modes. 
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I/O control signal lines . 8 

I/O device selection 73 
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I/O interface 71 

L 

LIFO (last in first out) 65 

Load and run timing 71 

Lock. 4-bit combination 82 
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Loops 52 

M 

Machine cycles 11 
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Memory read and write timing 69 
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Memory reference 15 
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Mode control 72 
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Multiple precision subtraction 46 
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N 
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Nesting 58 
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O 

One-level I/O system 77 
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P 
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Page 31 
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